应用环境
解决高并发,库存为负数的情况
阻塞模式
如果其他进程已经加锁文件,当前进程会一直等其他进程解锁文件后继续执行
flock($fp, LOCK_EX) // 文件锁
非阻塞模式
如果其他进程已经加锁文件,当前进程不会等其他进程解锁文件,直接返> 回,也就是直接忽略加锁的代码到关闭文件那块
flock($fp,LOCK_EX | LOCK_NB) // 文件锁
代码
flock($fp, LOCK_EX)
和 flock($fp,LOCK_EX | LOCK_NB)
换一下就行,其他都一样
<?php $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
相关推荐:
以上就是PHP中锁机制的应用的详细内容,更多请关注php中文网其它相关文章!
![php中文网最新课程二维码](/static/images/article_wechat2021.jpg?1111)
声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
网友评论
文明上网理性发言,请遵守 新闻评论服务协议
我要评论