redis真的是一个很好的技术,它可以很好的在一定程度上解决网站一瞬间的并发量,例如商品抢购秒杀等活动。
redis之所以能解决高并发的原因是它可以直接访问内存,而以往我们用的是数据库(硬盘),提高了访问效率,解决了数据库服务器压力。
为什么redis的地位越来越高,我们为何不选择memcache,这是因为memcache只能存储字符串,而redis存储类型很丰富(例如有字符串、LIST、SET等),memcache每个值最大只能存储1M,存储资源非常有限,十分消耗内存资源,而redis可以存储1G,最重要的是memcache它不如redis安全,当服务器发生故障或者意外关机等情况时,redsi会把内存中的数据备份到硬盘中,而memcache所存储的东西全部丢失;这也说明了memcache不适合做数据库来用,可以用来做缓存。
下面用redis解决瞬间秒杀活动来说明:
下面这个程序模拟了20人一瞬间涌入这个页面进行秒杀,能够秒杀成功的只有10人,我们把先进来的用户放入redis队列中,当队列中的用户达到10时,后来用户就转到秒杀结束页面。这里用随机数来表示不同的用户。
程序如下:这里只是单纯的模拟redis,具体应用还需要自行设计模式。
<?php$redis = new Redis();$redis->connect("127.0.0.1",6379);$redis_name = "miaoshaceshi";$num = 10;// 获取redis列表长度$len = $redis->llen($redis_name);if($len < $num){$uuid = mt_rand(100000,999999);$redis->rpush($redis_name,$uuid);echo "秒杀成功!";}else{echo "对不起,来晚了!";}// $r = $redis->lpop("miaoshaceshi");// var_dump($r);?>
我这里使用postman来模拟并发测试上边的代码。结果如下图所示:
有兴趣你可以自己试一下。
以上就是redis处理高并发的大概原理,当然,和实践还是有区别的。
有好的建议,请在下方输入你的评论。
欢迎访问个人博客
https://guanchao.site
欢迎访问小程序: