網(wǎng)站首頁 編程語言 正文
緩存問題
1. 緩存穿透---查不到
緩存穿透是指用戶想查詢一個(gè)數(shù)據(jù),發(fā)現(xiàn)Redis中沒有,也就是緩存沒有命中,就向持久性數(shù)據(jù)庫發(fā)起查詢,發(fā)現(xiàn)數(shù)據(jù)庫也沒有這個(gè)數(shù)據(jù),于是查詢失敗了。
當(dāng)用戶請求很多的情況下,緩存沒有命中,數(shù)據(jù)庫也沒有數(shù)據(jù),會給數(shù)據(jù)庫造成很大的壓力,這就是緩存穿透。
解決方案
第一種解決方案:使用布隆過濾器
使用布隆過濾器之后,將存儲的數(shù)據(jù)放入布隆過濾器中,每次數(shù)據(jù)查詢首先查詢布隆過濾器,當(dāng)在過濾器中判斷存在時(shí),再到緩存查詢,如果沒有,再進(jìn)入數(shù)據(jù)查詢。
如果在布隆過濾器中不存在,則直接返回告訴用戶該數(shù)據(jù)查不到,這樣能大大減輕數(shù)據(jù)庫查詢壓力。
第二種方案:緩存空對象
當(dāng)數(shù)據(jù)庫數(shù)據(jù)不存在時(shí),將返回的空對象緩存起來,同時(shí)設(shè)置一個(gè)過期時(shí)間,之后在訪問數(shù)據(jù)時(shí),將從緩存中獲取,從而保護(hù)了數(shù)據(jù)庫。
存在問題:
對空值設(shè)置過期時(shí)間,會存在更新數(shù)據(jù)庫數(shù)據(jù)到緩存數(shù)據(jù)失效的這一段時(shí)間,緩存數(shù)據(jù)有問題(問題在于緩存的空對象數(shù)據(jù),由于還沒有過期,但此時(shí)數(shù)據(jù)庫數(shù)據(jù)已經(jīng)更新了),會對要保證數(shù)據(jù)一致性的業(yè)務(wù)造成影響。會需要更多的空間來存儲更多的控制,造成內(nèi)存中有大量的空值的鍵。
2. 緩存擊穿---量太大,緩存過期
緩存擊穿是指一個(gè)熱點(diǎn)key,在不停的扛著大量的并發(fā),當(dāng)key在失效的瞬間,持續(xù)的大并發(fā)就會穿破緩存,直接請求到數(shù)據(jù)庫。對數(shù)據(jù)庫造成瞬間壓力過大。
解決方案
第一種方案:熱點(diǎn)數(shù)據(jù)永不過期
從緩存角度看,沒有設(shè)置過期時(shí)間,就不會存在緩存過期之后產(chǎn)生的問題。
第二種方案:加互斥鎖
使用分布式鎖,保證對每個(gè)key的訪問同一時(shí)刻只能一個(gè)線程去查詢后端服務(wù),其他沒有獲取鎖權(quán)限的線程則等待即可。
3. 緩存雪崩
緩存雪崩是指在某一個(gè)時(shí)間段,緩存集中過期失效或者Redis宕機(jī)
對于數(shù)據(jù)庫而言,所有請求壓力會全部到達(dá)數(shù)據(jù)庫,導(dǎo)致數(shù)據(jù)庫調(diào)用量暴增,可能也造成數(shù)據(jù)庫宕機(jī)的情況
解決方案
第一種方案(預(yù)防為主):Redis采用高可用
這種方案的思路就是集群使用,即使一個(gè)redis掛掉,其他redis還可以繼續(xù)服務(wù)。
第二種方案(降低發(fā)生時(shí)所造成的危害):限流降級
這種思路就是在緩存失效后,通過加鎖或者隊(duì)列來控制讀取數(shù)據(jù)庫的線程數(shù)量讓線程在隊(duì)列排隊(duì),控制整體請請求速率。
第三種方案:數(shù)據(jù)預(yù)熱
數(shù)據(jù)預(yù)熱即是在正式部署服務(wù)之前,先訪問一遍數(shù)據(jù),可以將大部分的數(shù)據(jù)加載到緩存中,在即將發(fā)生大并發(fā)之前已經(jīng)加載不同的key,設(shè)置不同的過期時(shí)間,讓緩存失效的時(shí)間更加均勻。
原文鏈接:https://blog.csdn.net/qq_45981295/article/details/121666465
相關(guān)推薦
- 2022-05-29 解決Docker容器下不能使用vim命令的問題_docker
- 2022-05-31 Python中的字典及其使用方法_python
- 2022-06-22 C++深入探究類與對象之友元與運(yùn)算符重載_C 語言
- 2022-05-12 C++深淺拷貝和string類的兩種寫法詳解_C 語言
- 2022-04-14 遇到一個(gè)git的大坑 src refspec master does not match any e
- 2022-08-14 在WPF中使用多線程更新UI_C#教程
- 2022-11-05 python?pandas?query的使用方法_python
- 2022-09-24 Golang?斷言與閉包使用解析_Golang
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支