0,就消耗令牌
if (local_curr_permits - permits >= 0 ) then
result=1
redis.call("HMSET",key,"last_second",ARGV[1])
redis.call("HMSET",key,"curr_permits",local_curr_permits - permits)
else
result=-1
--当前令牌如果减去消耗的令牌如果不大于0,那么表示令牌不够,重新加入令牌
redis.call("HMSET",key,"curr_permits",local_curr_permits)
end
return result
';
//转成微妙
$last=(int)(microtime(true)*1000);
//这次请求会消耗令牌
$permits=1;
$res=$redis->eval($lua,["{limit_1_2000}",$last,$permits],1);
//新建一个test.log 修改权限有可写,因为默认是www-data用户
if($res===1){
var_dump(file_put_contents('/var/www/html/test.log',$res."
",FILE_APPEND));
}else{
var_dump(file_put_contents('/var/www/html/test.log',"失败
",FILE_APPEND));
}
//通过压测看看持续几秒的请求,真正请求成功的有多少,其中-t 是持续时间
//ab -t 3 -c 1 -k http://127.0.0.1:8002/php/limit.php