php使用lua+redis实现限流,计数器模式,令牌桶模式

协程间可共享全局变量,同时要维护各自的调用栈结构;这两个要求目前在PHP的架构下较难实现。当然,非阻塞IO是可以通过libevent扩展实现,比如使用laruence的YAR。

php使用redis怎么解决秒杀中的超卖问题

超卖问题的根本原因还是在于并发,服务端对于并发处理的能力不足造成了超卖问题;

应对高并发问题一方面要提高服务端的请求处理能力,比如使用redis的事务(witch+multi)来提高处理速度。

另一方面就是削峰;常见的方案是通过消息队列缓冲瞬时请求高峰;通过消息队列可以吧同步请求转换成异步推送通知,通过队列一端承接瞬时访问高峰,另一端则平滑地将消息推送出去,达到削峰目的。

个人见解,希望对您的问题有所帮助!

使用redis 的队列+watch解决,把秒杀商品放入队列,抢到则pop商品,队列用完,则停止抢购

<?php

header("content-type:text/html;charset=utf-8");

$redis = new redis();

$result = $redis->connect('127.0.0.1', 6379);

$mywatchkey = $redis->get("mywatchkey");

$rob_total = 100; //抢购数量

if($mywatchkey<$rob_total){

$redis->watch("mywatchkey");

$redis->multi();

//设置延迟,方便测试效果。

sleep(5);

//插入抢购数据

$redis->hSet("mywatchlist","user_id_".mt_rand(1, 9999),time());

$redis->set("mywatchkey",$mywatchkey+1);

$rob_result = $redis->exec();

if($rob_result){

$mywatchlist = $redis->hGetAll("mywatchlist");

echo "抢购成功!<br/>";

echo "剩余数量:".($rob_total-$mywatchkey-1)."<br/>";

echo "用户列表:<pre>";

var_dump($mywatchlist);

}else{

echo "手气不好,再抢购!";exit;

phpredis,php使用lua+redis实现限流,计数器模式,令牌桶模式

}

}

?>