這篇文章主要介紹“怎么解決redis緩存問題”,在日常操作中,相信很多人在怎么解決redis緩存問題問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”怎么解決redis緩存問題”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
創(chuàng)新互聯(lián)從2013年成立,先為二連浩特等服務(wù)建站,二連浩特等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為二連浩特企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
1、緩存穿透;
緩存穿透是指查詢一個不存在的數(shù)據(jù),緩存中無該數(shù)據(jù)的信息,直接穿透緩存層直接到達(dá)數(shù)據(jù)庫層。
解決方案:
bloom filter:類似哈希表根據(jù)所有可能的查詢條件生成一個bitmap,在數(shù)據(jù)庫查詢時,會使用這個bitmap進(jìn)行過濾,不在其中就直接過濾篩選,從而減輕數(shù)據(jù)庫層面的壓力;
空值緩存:在第一次查詢完不存在的數(shù)據(jù)后,將該值的key與對應(yīng)的空值也放進(jìn)緩存中,只不過設(shè)定較短的失效時間,這樣可以應(yīng)對短時間大量的該key攻擊。
2、 緩存雪崩:
在普通的緩存系統(tǒng)中例如(redis、memcache)中,我們會給緩存設(shè)置一個失效時間,但是如果所有的緩存失效時間相同,那么在同一時間失效時,所有系統(tǒng)的請求都會送達(dá)數(shù)據(jù)庫,導(dǎo)致db可能承受不住如此大的壓力導(dǎo)致崩潰。
解決方案
線程互斥:只讓一個線程構(gòu)建緩存,其他線程等待構(gòu)建緩存的線程執(zhí)行完,每個時刻都只有一個線程在執(zhí)行請求,減輕db壓力,但缺點(diǎn)也很明顯,降低了系統(tǒng)QPS(1s的請求數(shù)量)
交錯失效時間:在緩存失效時間設(shè)置的時候,從某個適當(dāng)?shù)闹涤蛑须S機(jī)一個時間作為失效的時間即可;
3、緩存擊穿:
緩存雪崩的一個特例,區(qū)別:擊穿是對于特定的熱點(diǎn)數(shù)據(jù),而雪崩的是全部數(shù)據(jù)。熱門話題,當(dāng)緩存達(dá)到失效時間時,依然有大量的請求的達(dá)到系統(tǒng),沒有緩存層的保護(hù),直接達(dá)到db引起的故障。
解決方案:
二級緩存:對于熱點(diǎn)數(shù)據(jù)進(jìn)行二級緩存,并對于不同級別的緩存設(shè)定不同的失效時間,則請求不會直接擊穿達(dá)到db(怎么二級緩存的界限可以考慮LRU算法“最近最少使用算法”)
到此,關(guān)于“怎么解決redis緩存問題”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!