电商的秒杀功能是现在电商系统的主流功能;
参加过电商秒杀的都知道,有时候会遇到商品明显没有了,用户还可以下单导致秒杀商品的库存时常为负数。
秒杀系统就是典型的、短时间的、大量的、突发访问;这样的短时大并发的系统,在性能负载上面有一个很明显的波峰和长期波谷。是为了应对相当短时间内的大并发而准备大量服务器来应对,在经济上是非常不划算的。因此呢,对付秒杀类的需求,我们就应该化同步为异步,用户请求写入内存后立刻返回。后台启动多个线程从内存池中异步读取数据,对其进行处理。
![25607d8c2ffcfb8cdaebfedc924d0ea6.png](https://img-blog.csdnimg.cn/img_convert/25607d8c2ffcfb8cdaebfedc924d0ea6.png)
异步处理,通常用MQ(消息队列)来实现。redis可以看作是一个高性能的MQ。因为它的数据读写都发生在内存之中。写入内存,而不是写入硬盘。redis是一个缓存系统,数据写入内存后就返回给客户端,能够支持这个特性;所以使用redis就可以轻松实现一个强大的秒杀系统。
例如:<?Php //php秒杀 redis并发处理 function miaoshao(){$redis = new Redis; //diy redis操作类 //连接 $redis->connect('127.0.0.1', 6379,30); //设置密码 $redis->auth('junyi');//获取库存出售的数量,默认为空 $kuchun = $redis -> get('kucun');$total = 100; if ($kuchun < $total){//有库存 $redis -> watch('kucun');//开启事务 $redis->multi();$redis->set("kucun",$kuchun+1);//执行事务 $result = $redis->exec(); if($result){//剩余数量 $number = $total - ($kuchun +1);//$openid 用户id $openid = $number;$redis-> hset("list","user_".$openid,$kuchun);//获取抢购成功的用户 $data = $redis-> hgetall('list');var_dump($data);var_dump($number);}else{var_dump('手气很差哦,再试一下!');}}else{ var_dump('已经被抢光了');} }
这样以来就能使用reids实现电商秒杀系统了。