亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Redis中緩存穿透/擊穿/雪崩問題和解決方法

 更新時間:2021年12月03日 09:27:03   作者:靜靜子?  
大家好,本篇文章主要講的是Redis中緩存穿透/擊穿/雪崩問題和解決方法,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下哦,方便下次瀏覽

緩存問題

1. 緩存穿透---查不到

緩存穿透是指用戶想查詢一個數(shù)據(jù),發(fā)現(xiàn)Redis中沒有,也就是緩存沒有命中,就向持久性數(shù)據(jù)庫發(fā)起查詢,發(fā)現(xiàn)數(shù)據(jù)庫也沒有這個數(shù)據(jù),于是查詢失敗了。

當(dāng)用戶請求很多的情況下,緩存沒有命中,數(shù)據(jù)庫也沒有數(shù)據(jù),會給數(shù)據(jù)庫造成很大的壓力,這就是緩存穿透。

解決方案

第一種解決方案:使用布隆過濾器

使用布隆過濾器之后,將存儲的數(shù)據(jù)放入布隆過濾器中,每次數(shù)據(jù)查詢首先查詢布隆過濾器,當(dāng)在過濾器中判斷存在時,再到緩存查詢,如果沒有,再進入數(shù)據(jù)查詢。

如果在布隆過濾器中不存在,則直接返回告訴用戶該數(shù)據(jù)查不到,這樣能大大減輕數(shù)據(jù)庫查詢壓力。

第二種方案:緩存空對象

當(dāng)數(shù)據(jù)庫數(shù)據(jù)不存在時,將返回的空對象緩存起來,同時設(shè)置一個過期時間,之后在訪問數(shù)據(jù)時,將從緩存中獲取,從而保護了數(shù)據(jù)庫。

存在問題:

對空值設(shè)置過期時間,會存在更新數(shù)據(jù)庫數(shù)據(jù)到緩存數(shù)據(jù)失效的這一段時間,緩存數(shù)據(jù)有問題(問題在于緩存的空對象數(shù)據(jù),由于還沒有過期,但此時數(shù)據(jù)庫數(shù)據(jù)已經(jīng)更新了),會對要保證數(shù)據(jù)一致性的業(yè)務(wù)造成影響。會需要更多的空間來存儲更多的控制,造成內(nèi)存中有大量的空值的鍵。

2. 緩存擊穿---量太大,緩存過期

緩存擊穿是指一個熱點key,在不停的扛著大量的并發(fā),當(dāng)key在失效的瞬間,持續(xù)的大并發(fā)就會穿破緩存,直接請求到數(shù)據(jù)庫。對數(shù)據(jù)庫造成瞬間壓力過大。

解決方案

第一種方案:熱點數(shù)據(jù)永不過期

從緩存角度看,沒有設(shè)置過期時間,就不會存在緩存過期之后產(chǎn)生的問題。

第二種方案:加互斥鎖

使用分布式鎖,保證對每個key的訪問同一時刻只能一個線程去查詢后端服務(wù),其他沒有獲取鎖權(quán)限的線程則等待即可。

3. 緩存雪崩

緩存雪崩是指在某一個時間段,緩存集中過期失效或者Redis宕機

對于數(shù)據(jù)庫而言,所有請求壓力會全部到達數(shù)據(jù)庫,導(dǎo)致數(shù)據(jù)庫調(diào)用量暴增,可能也造成數(shù)據(jù)庫宕機的情況

解決方案

第一種方案(預(yù)防為主):Redis采用高可用

這種方案的思路就是集群使用,即使一個redis掛掉,其他redis還可以繼續(xù)服務(wù)。

第二種方案(降低發(fā)生時所造成的危害):限流降級

這種思路就是在緩存失效后,通過加鎖或者隊列來控制讀取數(shù)據(jù)庫的線程數(shù)量讓線程在隊列排隊,控制整體請請求速率。

第三種方案:數(shù)據(jù)預(yù)熱

數(shù)據(jù)預(yù)熱即是在正式部署服務(wù)之前,先訪問一遍數(shù)據(jù),可以將大部分的數(shù)據(jù)加載到緩存中,在即將發(fā)生大并發(fā)之前已經(jīng)加載不同的key,設(shè)置不同的過期時間,讓緩存失效的時間更加均勻。

到此這篇關(guān)于Redis中緩存穿透/擊穿/雪崩問題和解決方法的文章就介紹到這了,更多相關(guān)Redis緩存穿透/擊穿/雪崩問題內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解如何利用Redis實現(xiàn)生成唯一ID

    詳解如何利用Redis實現(xiàn)生成唯一ID

    隨著下單流量逐漸上升,為了降低數(shù)據(jù)庫的訪問壓力,需要通過請求唯一ID+redis分布式鎖來防止接口重復(fù)提交。今天我們就一起來看探討一下,如何通過服務(wù)端來完成請求唯一?ID?的生成
    2022-11-11
  • Redis 實現(xiàn)同步鎖案例

    Redis 實現(xiàn)同步鎖案例

    這篇文章主要介紹了Redis 實現(xiàn)同步鎖案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • 高并發(fā)技巧之Redis和本地緩存使用技巧分享

    高并發(fā)技巧之Redis和本地緩存使用技巧分享

    在這篇文章中,我主要介紹的是分布式緩存和本地緩存的使用技巧,包括緩存種類介紹,各種的使用場景,以及如何使用,最后再給出實戰(zhàn)案例,需要的可以參考一下
    2022-10-10
  • 簡單粗暴的Redis數(shù)據(jù)備份和恢復(fù)方法

    簡單粗暴的Redis數(shù)據(jù)備份和恢復(fù)方法

    這里我們來講解一個簡單粗暴的Redis數(shù)據(jù)備份和恢復(fù)方法,有一個在不同主機上遷移Redis數(shù)據(jù)的示例,還有一個備份腳本實現(xiàn)的關(guān)鍵點提示,一起來看一下:
    2016-06-06
  • Redis5之后版本的高可用集群搭建的實現(xiàn)

    Redis5之后版本的高可用集群搭建的實現(xiàn)

    這篇文章主要介紹了Redis5之后版本的高可用集群搭建的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Redis定時任務(wù)原理的實現(xiàn)

    Redis定時任務(wù)原理的實現(xiàn)

    本文主要是基于?redis?6.2?源碼進行分析定時事件的數(shù)據(jù)結(jié)構(gòu)和常見操作,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 硬核!15張圖解Redis為什么這么快(推薦)

    硬核!15張圖解Redis為什么這么快(推薦)

    作為一名服務(wù)端工程師,工作中你肯定和 Redis 打過交道。Redis為什么快,這點想必你也知道,至少為了面試也做過準備,今天通過本文給大家介紹下,感興趣的朋友一起看看吧
    2020-10-10
  • Redis 中spark參數(shù)executor-cores引起的異常解決辦法

    Redis 中spark參數(shù)executor-cores引起的異常解決辦法

    這篇文章主要介紹了Redis 中spark參數(shù)executor-cores引起的異常解決辦法的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • redis?for?windows?6.2.6安裝包最新步驟詳解

    redis?for?windows?6.2.6安裝包最新步驟詳解

    這篇文章主要介紹了redis?for?windows?6.2.6安裝包全網(wǎng)首發(fā),使用Windows計劃任務(wù)自動運行redis服務(wù),文章給大家講解的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • Redis持久化方式之RDB和AOF的原理及優(yōu)缺點

    Redis持久化方式之RDB和AOF的原理及優(yōu)缺點

    在Redis中,數(shù)據(jù)可以分為兩類,即內(nèi)存數(shù)據(jù)和磁盤數(shù)據(jù),Redis?提供了兩種不同的持久化方式,其中?RDB?是快照備份機制,AOF?則是追加寫操作機制,本文將詳細給大家介紹Redis?持久化方式RDB和AOF的原理及優(yōu)缺點,感興趣的同學(xué)可以跟著小編一起來學(xué)習(xí)
    2023-06-06

最新評論