一 生产者producer部分
--------------------------------producer 部分注释------------------------------------------------------------
用户在页面请求之后, 获取到用户uid , 跳转到这个加入队列的方法 (这里直接在producer中模拟了多个uid)
在方法内部判断redis队列长度是否已经达到要求, 如果没有超出, 则执行加入队列的操作 (这里为了简洁,没有封装成方法)
注: producer.php没有进行数据库的操作,只有接受uid和其他值的操作, 数据库操作一律放在消费者consumer.php中
--------------------------------producer 注释结束-----------------------------------------------------------------------
生产者代码 producer.php:
<?php
//连接redis数据库
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
$redis_name = 'secKill3';
//模拟100人请求秒杀(高压力)
for ($i = 0; $i < 100; $i++) {
$uid = rand(10000000, 99999999);
//获取当前队列已经拥有的数量,如果人数少于十,则加入这个队列
$num = 10;

该博客介绍了如何利用Redis的List数据结构来创建一个简单的秒杀系统。在生产者部分,用户请求后,将uid加入队列,当队列长度未超过限制时执行。消费者部分则持续读取队列,一旦有值,立即处理并执行数据库操作。整个过程避免了在生产者端进行数据库交互,确保了系统的高效性。
最低0.47元/天 解锁文章
1574

被折叠的 条评论
为什么被折叠?



