基于php和redis如何设计一个秒杀系统?

发布于 2022-09-06 20:17:12 字数 82 浏览 16 评论 0

基于php和redis如何设计一个秒杀系统?

大概的要求是:能处理高并发请求,抢购成功但是在规定时间内未支付的订单需要从新回到系统。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

迷迭香的记忆 2022-09-13 20:17:12

秒杀可以考虑使用redis队列来实现。

对于30分钟未支付的订单有两种方案可考虑:

第一种方案:被动过期+cron,就是用户查看的时候去数据库查有没有支付+定时清理。
第二种方案:延迟性任务,到时间检查订单是否支付成功,如果没有支付则取消订单。

腹黑女流氓 2022-09-13 20:17:12

我自己想一个大概思路:分为两部分 1.先由Api随机踢掉一部分用户,让少部分流量打到后段业务;2.由于秒杀,所以必须要要控制超卖,建议使用Redis队列预先把商品写入队列中,到点使用key去pop,如果pop出有,则视为抢到,这样可以防止超卖。长期未为购买的用户,可以使用cron来跑,或者把生成的订单号,放到redis里面去,结算的时候踢掉,然后使用cron进行辅助。或者可以使用beanstalk,延时任务队列。最好都还是用cron来辅助。大概思路就这样。

笑饮青盏花 2022-09-13 20:17:12

Redis有一个list的数据结构可以满足你的需求,详情可以看一下慕课网的教程高峰削流

清醇 2022-09-13 20:17:12
<?php
$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;
    }
}
?>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文