PHP中锁机制的应用

应用环境

解决高并发,库存为负数的情况

阻塞模式

如果其他进程已经加锁文件,当前进程会一直等其他进程解锁文件后继续执行

flock($fp, LOCK_EX) // 文件锁

非阻塞模式

如果其他进程已经加锁文件,当前进程不会等其他进程解锁文件,直接返> 回,也就是直接忽略加锁的代码到关闭文件那块

flock($fp,LOCK_EX | LOCK_NB) // 文件锁

代码

flock($fp, LOCK_EX) 和 flock($fp,LOCK_EX | LOCK_NB) 换一下就行,其他都一样

$fp = fopen('lock.txt', 'r');

if( flock($fp, LOCK_EX) ){ // flock($fp,LOCK_EX | LOCK_NB)

$info = D()->query('SELECT surplus_total_num FROM tb_product WHERE id=1 LIMIT 1');

if( $info['surplus_total_num'] > 0 ){

D()->execute('UPDATE tb_product SET surplus_total_num = surplus_total_num - 1 WHERE id=1');

$isSurplusProduct = 1;

}else{

$isSurplusProduct = 0;

}

flock($fp, LOCK_UN);

}

fclose($fp);

if( !$isSurplusProduct ) exit('已经没有产品了');

并发测试

查看数据库的库存是否一致保持为0 ab参数:-c:并发数;-n:总请求数

ab -c 20 -n 1000 http://www.test.com/test.php

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180806A1VMFJ00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券