目前我用的是在session中设置一个值,每次进来判断这个值是否存在,存在就表示锁定了,不执行本次请求,如果不存在,就设置这个值,并执行后续操作。
class controller{
function index(){
if(isset($_SESSION['lock']))
return;
$_SESSION['lock'] = 1;
sleep(1);//这里会查询用户的资格,并给用户发送流量,如果两次同时进来,会造成两次都认为是有资格的,并且会给用户发两次相同流量
unset($_SESSION['lock']);
}
}
我本以为这样做是可以的,而且session存在redis里速度蛮快,直到刚才睡不着起来摆弄,发现竟然还是能让一个用户同时的多次同接口请求都执行了。
想要一个人的同时多次请求,只处理第一个。判断是否同一人,根据session来判断。
你们是用什么方法保证这个的?
1,如使用Mysql,可以对Mysql进行加锁,一个请求结束以后,释放锁其它请求才能往下执行
2,可以使用计数器,在请求进来的可以往计数器里加一,请求结束以后清空计数器,较推荐这个方法
3,另外,文件的session本身是有锁的,如果同一个用户的每一次请求未结束,其它请求也会在被阻塞
不少人问session锁的问题,看下这篇文章吧
https://log.zvz.im/2016/02/27...