导航:首页 > 数据处理 > 数据库崩了是什么原因

数据库崩了是什么原因

发布时间:2024-09-17 15:52:26

⑴ redis产生雪崩怎么解决



产生雪崩的原因:
缓存雪崩通俗简单的理解就是:由于原有缓存失效(或者数据未加载到缓存中),新缓存未到期间(缓存正常从Redis中获取,如下图)所有原本应该访问缓存的请求都去查询数据库了,而对数据库CPU和内存造成巨大压力,严重的会造成数据库宕机,造成系统的崩溃。
基本解决思路如下:
第一,大多数系统设计者考虑用加锁或者队列的方式保证来保证不会有大量的线程对数据库一次性进行读写,避免缓存失效时对数据库造成太大的压力,虽然能够在一定的程度上缓解了数据库的压力但是与此同时又降低了系统的吞吐量。
第二,分析用户的行为,尽量让缓存失效的时间均匀分布。
第三,如果是因为某台缓存服务器宕机,可以考虑做主备,比如:redis主备,但是双缓存涉及到更新事务的问题,update可能读到脏数据,需要好好解决。
Redis雪崩效应的解决方案:
1、可以使用分布式锁,单机版的话本地锁
2、消息中间件方式
3、一级和二级缓存Redis+Ehchache
4、均摊分配Redis的key的失效时间
解释:
1、 当突然有大量请求到数据库服务器时候,进行请求限制。使用所的机制,保证只有一个线程(请求)操作。否则进行排队等待(集群分布式锁,单机本地锁)。减少服务器吞吐量,效率低。
加入锁!
保证只能有一个线程进入 实际上只能有一个请求在执行查询操作
也可以在此处进行使用限流的策略~
2、使用消息中间件解决
这种方案是最靠谱的方案!
消息中间件可以解决高并发!!!
如果大量的请求进行访问时候,Redis没有值的情况,会将查询的结果存放在消息中间件中(利用了MQ异步步特性)
3、做二级缓存,A1为原始缓存,A2为拷贝缓存,A1失效时,可以访问A2,A1缓存失效时间设置为短期,A2设置为长期(此点为补充)
4、不同的key,设置不同的过期时间,让缓存失效的时间点尽量均匀。
更多Redis相关知识,请访问Redis使用教程栏目!

阅读全文

与数据库崩了是什么原因相关的资料

热点内容
女生过三十岁后学什么技术 浏览:991
外汇交易单中tp表示什么 浏览:1
王者策划技术怎么样 浏览:319
代理记账公司怎么切户 浏览:334
mac抹掉所有内容和数据密码是什么 浏览:792
数据线写的g4什么意思 浏览:491
手机怎么下载博易大师模拟交易 浏览:531
手机使用读卡器用什么数据线 浏览:566
首师大遥感技术与应用专业如何 浏览:615
代理行为怎么有效 浏览:287
如何做全国推广的产品 浏览:455
产品不做了怎么打报告 浏览:848
怎么查街道人员信息 浏览:13
哪个交易游戏平台永久包赔 浏览:898
权健产品如何搭配 浏览:295
阿里的广告产品有哪些 浏览:219
信息社会治理模式有哪些 浏览:148
微盟小程序是什么意思 浏览:43
福田奥铃有哪些产品 浏览:213
图像处理产品有哪些 浏览:509