自己见过的锁都是类似先定义一个变量 = true, 相关操作完成之后再把相关的值变成false.
$lock_num = 0;
while(!redis_helper::lock("lottery")) {
if($lock_num >= 300) {
return "亲,好多人在排队抢红包啊,请重新进入页面";
}
// 0.1s
usleep(100000);
$lock_num ++;
}
下面是并发锁定的相关函数, 自己能明白这个锁每6s会变换一次真假值,但是不明白结合上面的$lock_num针对的并发情况到底是啥? 没6s变换真假值,6s/0.1s = 60次,怎么会达到300,页面卡住了,其他人恰好重新将锁设置为假?
/**
* 并发锁定
* @param string $name 锁名称
* @param int $expires 超时失效的时间,单位秒
* @return bool true:获取锁成功,false:获取锁失败
*/
public static function lock($name, $expires = 5)
{
self::init_redis();
$key = $name . '_lock';
$now = time();
$val = $now + $expires + 1;
if(self::$redis->setnx($key, $val)) {
return true;
} else {
$old_val = self::$redis->get($key);
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。