本文介绍: 比如说,在 11 点的时候大家都去饿了么点外卖,这个时候饿了么的Redis 中就存了一大批商家的信息,并且饿了么的程序员给这个缓存设置的过期时间是 6 个小时。那么到下午 5 点晚饭时间又是一大波人来饿了么点外卖,这个时候 Redis 的缓存刚刚好集体过期了,短时间内大量的查询请求就全部落到了脆弱的MySql 上,导致 MySql 直接爆炸!在缓存失效的时候(判断拿出来的值为空),第1个进入的线程,获取锁并从数据库去取数据,没释放锁之前,其他并行进入的线程会等待,再重新去缓存取数据。
1 Redis 缓存过程
通常后端会采用Mysql等磁盘数据库,可以持久化但是访问慢,高并发时性能差,需要设置Nosql内存型数据库缓存:Redis等;
Redis 数据库运行在内存中,因此他的查询速度比 MySql 快的多。所以我们会把一些用户经常查询的数据放在 Redis 中,当 Redis 有的时候就直接返回,当 Redis 中没有的时候再去数据库中查找。以此增加服务的运行效率。
但缓存可能出现:缓存穿透、缓存击穿、缓存雪崩等问题。
2 缓存雪崩
原文地址:https://blog.csdn.net/u013938578/article/details/135564138
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_55734.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。