您的位置 首页 php

php如何实现秒杀功能?php+redis模拟简单抢购场景,快来看看吧

本文用到的知识点需要提前安装redis,php如何安装redis请看之前的文章。

场景:在某个时间点对商品goods_id=2的商品进行抢购,商品库存为10

建立商品goods_id=2的库存抢购列表

首先创建待抢购商品的list列表,如果有人抢购成功就移除一个,直到列表为空则表示抢购完成。

 //1、连接redis数据库
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis_name = 'goods_id_2';//比如商品id=2的商品参与秒杀
//2、模拟抢购,库存为10,将库存放到redis中
$num = 10;
for($i=0;$i<$num;$i++){
	$redis->lPush($redis_name,1);//这里用某个商品的ID作为标识
}
echo "执行成功";  

客户端进行模拟抢购

 //1、连接redis数据库
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis_name = 'goods_id_2';//比如商品id=2的商品参与秒杀


//3、模拟用户请求,随机获取10名用户表示抢购成功
for($i=0;$i<100;$i++){
	$user_id = rand(100,999);
	$len = $redis->lLen($redis_name);
	$str = "";
	if(!$len || $len<=0){
		$str .= $user_id."抢购已结束";
		break;
	}else{
		$redis_user_name = "goods_id_2_user_id";
		//判断抢购列表中是否已存在该用户,获取列表中所有的数据
		$skill_list = $redis->lrange($redis_user_name, 0, -1);
		if(in_array($user_id, $skill_list)){
			$str .= $user_id."请勿重复提交";
		}else{
			$redis->rPop($redis_name);
			$redis->lPush($redis_user_name,$user_id."_".ceil(microtime(true)*1000));
			$str .= $user_id."已抢到";
		}
	}
	file_put_contents("D:/wwwroot/test/skill/cron.txt", $str."\r\n",FILE_APPEND);
}

echo '执行完成';  

服务端执行队列处理,将redis中已抢购的用户保存到数据库中

 <?php
$mysql_server_name = 'localhost'; //改成自己的mysql数据库服务器
$mysql_username = 'root'; //改成自己的mysql数据库用户名
$mysql_password = '123456'; //改成自己的mysql数据库密码
$mysql_database = 'test'; //改成自己的mysql数据库名
$conn=mysqli_connect($mysql_server_name,$mysql_username,$mysql_password,$mysql_database); //连接数据库
//连接数据库错误提示
if (mysqli_connect_errno($conn)) {
	die("连接 MySQL 失败: " . mysqli_connect_error());
}
mysqli_query($conn,"set names utf8"); //数据库编码格式
//1、连接redis数据库
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis_name = 'goods_id_2';//比如商品id=2的商品参与秒杀
//2、将list队列中的数据读取出来然后执行入库
$redis_user_name = "goods_id_2_user_id";
while(true){
	//判断抢购列表中是否已存在该用户,获取列表中所有的数据
	$result = $redis->rpop($redis_user_name);
	if($result){
		$skill_arr = array_filter(explode("_", $result));
		$sql = "insert into skill (user_id,timestamp) values({$skill_arr[0]},{$skill_arr[1]})";
		mysqli_query($conn,$sql); 
	}
}
echo "执行成功";  

以上就是简单实现秒杀的场景,具体的代码还要根据实际的逻辑进行调整。

你学会了吗,赶紧点赞收藏试一试吧。

我是小程序软件开发,每天分享开发过程中遇到的知识点,如果对你有帮助的话,帮忙点个赞再走呗,非常感谢。

往期文章分享:

文章来源:智云一二三科技

文章标题:php如何实现秒杀功能?php+redis模拟简单抢购场景,快来看看吧

文章地址:https://www.zhihuclub.com/78524.shtml

关于作者: 智云科技

热门文章

网站地图