RRRena

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

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

阻塞与非阻塞

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

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

 

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接口,而你此时又不关心返回值的时候。





posted on 2018-01-15 15:58  RRRena  阅读(4934)  评论(0编辑  收藏  举报