[one_demo_1]php中的文件锁

<?php
/**
 * 使用php的文件锁解决高并发下操作数据库可能出现的争抢数据问题
 * 与mysql的锁表相比的优势,不影响此表被其他功能使用。
 * 应用场景:购物秒杀,各种票的抢票等。
 * create table a(id smallint);
 * insert into a values (100);
 */
error_reporting(0);
mysql_connect('localhost', 'root', '123456');
mysql_select_db('testphp');
//创建一个文件,打开它,加排它锁
$fp = fopen('./a.lock', r);
flock($fp, LOCK_EX);
$rs = mysql_query('select id from a');
$id = mysql_result($rs, 0, 0);
if($id > 0)
{
$id --;
mysql_query('update a set id ='.$id);
}
//解锁这个文件,关闭文件
flock($fp, LOCK_UN);
fclose($fp);
//使用apache的ab.exe文件做压力测试
//cmd中,在apche的bin目录下,ab.exe -c 20 -n 20 http://www.php2.com/suo/suodemo.php

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值