参加过电商秒杀的都知道,有时候会碰着商品明显没有了,用户还可以下单导致秒杀商品的库存时常为负数。
秒杀系统便是范例的、短韶光的、大量的、突发访问;这样的短时大并发的系统,在性能负载上面有一个很明显的波峰和长期波谷。是为了应对相称短韶光内的大并发而准备大量做事器来应对,在经济上是非常不划算的。因此呢,对付秒杀类的需求,我们就该当化同步为异步,用户要求写入内存后急速返回。后台启动多个线程从内存池中异步读取数据,对其进行处理。
异步处理,常日用MQ(行列步队)来实现。redis可以看作是一个高性能的MQ。由于它的数据读写都发生在内存之中。写入内存,而不是写入硬盘。redis是一个缓存系统,数据写入内存后就返回给客户端,能够支持这个特性;以是利用redis就可以轻松实现一个强大的秒杀系统。

例如:<?Php//php秒杀 redis并发处理functionmiaoshao(){$redis= newRedis; //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实现电商秒杀系统了。