zoukankan      html  css  js  c++  java
  • php阻塞模式与非阻塞模式

    首先说一下概念,有很多人不理解这个概念。如果看完后还是一头雾水就多读几次。

    阻塞与非阻塞

    阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态.

    阻塞调用是指调用结果返回之前,当前线程会被挂起。调用线程只有在得到结果之后才会返回。
    非阻塞调用指在不能立刻得到结果之前,该调用不会阻塞当前线程。

    1.php并发阻塞。

      对于php来说并发是个问题,工作中经常会碰到一些,写库之前的查询,判断数据是否存在,但是如果并发的情况下,就会导致数据重复写入,而你的判断也成了虚设。所以有了阻塞,我们需要把请求一条一条的执行。

    简单介绍:
    1.首先,读写方式打开或者创建文件lock.txt文件
    2.给lock.txt文件上 "独占锁",上锁成功后就可以进行下一步"处理订单商品数据了"
    3.处理完数据后,要"释放锁”,以及fclose关闭打开的文件
    注意:给文件“独占锁”后,如果再没有里面的“释放锁”,会出现非常卡的情况

    fopen详细介绍:http://www.w3school.com.cn/php/func_filesystem_fopen.asp

    flock详细介绍:http://www.w3school.com.cn/php/func_filesystem_flock.asp

    fclose详细介绍:http://www.w3school.com.cn/php/func_filesystem_fclose.asp

    public function index(){
        $fp = fopen("lock.txt", "w+");
    if(flock($fp,LOCK_EX))
    {
    $find=Db::name('user')->where('username','name2')->find();
    if($find){
    $data['username']='name3';
    $data['password']='';
    $data['password_m']='';
    Db::name('user')->insert($data);
    }else{
    $data['username']='name2';
    $data['password']='';
    $data['password_m']='';
    Db::name('user')->insert($data);
    }

    flock($fp,LOCK_UN);
    }
    fclose($fp);

    return
    'success';

    }
    注意:对于小并发可行,而且性能不会出现大的影响。并发小于500较好,如果过高的话,建议使用队列模式。

    2.php非阻塞模式
    非阻塞模式我们常用在php程序内部调用第三方api接口,或者不需要等待结果的程序。

    举一个简单的例子。发送邮件,你要发送给你的所有的老大,那么你需要全部都发送一遍,也许你得写一个循环,那么这一个循环中发邮件的方法需要执行时间,需要拿到返回值,执行下一次循环,这个时间依次累加,最后时间会边的很长,
    那么这种被称之为阻塞,而我们一直想要的是提交过去,不需要等待返回数据,你就循环的跑一遍就好了,那么我们想的这个就是非阻塞模式。对于这种的话,php也没有什么好的函数来处理,所以我们做的最多的还是队列出来,发邮件的时候,
    根据队列去执行,其实用到的还是阻塞模式。但是我们的请求执行时间会被压缩的很短,最常用的就是调用API接口,而你此时又不关心返回值的时候。





    我要去Facebook
  • 相关阅读:
    web前端安全---读书笔记
    三色旗
    Pascal三角形
    汉诺塔算法
    冒泡排序算法
    HttpRunner 参数化数据驱动
    swagger接口变动监控
    HttpRunnerManager平台异步生成及展示代码覆盖率报告(ant+jacoco+jenkins+HttpRunnerManager)
    SonarQube+jenkins+maven平台搭建
    requests 模块
  • 原文地址:https://www.cnblogs.com/rrrena/p/8288469.html
Copyright © 2011-2022 走看看