成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

緩存穿透、并發(fā)和失效、同步中斷,最佳實(shí)踐及優(yōu)化方案

funnyZhang / 2502人閱讀

摘要:當(dāng)緩存空間滿了,同步失敗,網(wǎng)絡(luò)阻塞,緩存寫失敗等原因,會(huì)出現(xiàn)緩存服務(wù)器上并沒有這個(gè)。這種問題,以前有過實(shí)踐,修改數(shù)據(jù)庫成功,而修改緩存失敗的情況,最主要就是緩存服務(wù)器掛了。而緩存服務(wù)器掛了,請求首先自然也就無法到達(dá),從而直接訪問到數(shù)據(jù)庫。

原文摘自:

緩存穿透、并發(fā)和失效,來自一線架構(gòu)師的解決方案
https://community.qingcloud.com/topic/463

在我們的實(shí)踐中,原文中有部分解決方案已經(jīng)過時(shí),在原文的基礎(chǔ)上,添加了幾個(gè)我們常用的方案。

http://www.4wei.cn/archives/1002621


我們在用緩存的時(shí)候,不管是Redis或者M(jìn)emcached,基本上會(huì)通用遇到以下三個(gè)問題:

緩存穿透

緩存并發(fā)

緩存失效

同步、復(fù)制中斷

緩存穿透



注:上面三個(gè)圖會(huì)有什么問題呢?

我們在項(xiàng)目中使用緩存通常都是先檢查緩存中是否存在,如果存在直接返回緩存內(nèi)容,如果不存在就直接查詢數(shù)據(jù)庫然后再緩存查詢結(jié)果返回。

這個(gè)時(shí)候如果我們查詢的某一個(gè)數(shù)據(jù)在緩存中一直不存在,就會(huì)造成每一次請求都查詢DB,這樣緩存就失去了意義,在流量大時(shí),可能DB就掛掉了。

那這種問題有什么好辦法解決呢?

要是有人利用不存在的key頻繁攻擊我們的應(yīng)用,這就是漏洞。有一個(gè)比較巧妙的作法是,可以將這個(gè)不存在的key預(yù)先設(shè)定一個(gè)值。比如,"key" , “&&”。

在返回這個(gè)&&值的時(shí)候,我們的應(yīng)用就可以認(rèn)為這是不存在的key,那我們的應(yīng)用就可以決定是否繼續(xù)等待繼續(xù)訪問,還是放棄掉這次操作。如果繼續(xù)等待訪問,過一個(gè)時(shí)間輪詢點(diǎn)后,再次請求這個(gè)key,如果取到的值不再是&&,則可以認(rèn)為這時(shí)候key有值了,從而避免了透傳到數(shù)據(jù)庫,從而把大量的類似請求擋在了緩存之中。

你應(yīng)該注意,這里緩存未命中的原因,更值得我們關(guān)注。

當(dāng)緩存空間滿了,同步失敗,網(wǎng)絡(luò)阻塞,緩存寫失敗等原因,會(huì)出現(xiàn)緩存服務(wù)器上并沒有這個(gè)key。
或者因?yàn)橥街袛?,在主從架?gòu)中,寫到主卻未同步到從的悲劇,就會(huì)出現(xiàn)請求穿透到DB層的情況。

出現(xiàn)這樣的情況,一定不能直接將請求穿透到DB層,避免DB當(dāng)機(jī)影響其它業(yè)務(wù)。
我們的解決方案可以參考。

當(dāng)業(yè)務(wù)中請求量特別高,緩存未命中的情況,應(yīng)該在建立DB保護(hù)的基礎(chǔ)上,放棄一定比例的請求,直接返回空

可以隨機(jī)釋放一些請求到DB,控制好流量的話,能保證緩存重建且DB不受極端壓力

后端異步定時(shí)檢查緩存,主動(dòng)建立這些緩存

部分頁面可緩存永不過期,后端異步定時(shí)檢查緩存,主動(dòng)更新、重建緩存,后端失效也可實(shí)現(xiàn)業(yè)務(wù)降級

通過建立二級緩存,把之前成功獲取的緩存數(shù)據(jù)放到本機(jī)緩存,文件也好,共享內(nèi)存也好,接受一些過期數(shù)據(jù)

緩存并發(fā)

有時(shí)候如果網(wǎng)站并發(fā)訪問高,一個(gè)緩存如果失效,可能出現(xiàn)多個(gè)進(jìn)程同時(shí)查詢DB,同時(shí)設(shè)置緩存的情況,如果并發(fā)確實(shí)很大,這也可能造成DB壓力過大,還有緩存頻繁更新的問題。
我現(xiàn)在的想法是對緩存查詢加鎖,如果KEY不存在,就加鎖,然后查DB入緩存,然后解鎖;其他進(jìn)程如果發(fā)現(xiàn)有鎖就等待,然后等解鎖后返回?cái)?shù)據(jù)或者進(jìn)入DB查詢。

這種情況和剛才說的預(yù)先設(shè)定值問題有些類似,只不過利用鎖的方式,會(huì)造成部分請求等待。

緩存失效

引起這個(gè)問題的主要原因還是高并發(fā)的時(shí)候,平時(shí)我們設(shè)定一個(gè)緩存的過期時(shí)間時(shí),可能有一些會(huì)設(shè)置1分鐘啊,5分鐘這些,并發(fā)很高時(shí)可能會(huì)出在某一個(gè)時(shí)間同時(shí)生成了很多的緩存,并且過期時(shí)間都一樣,這個(gè)時(shí)候就可能引發(fā)一當(dāng)過期時(shí)間到后,這些緩存同時(shí)失效,請求全部轉(zhuǎn)發(fā)到DB,DB可能會(huì)壓力過重。

那如何解決這些問題呢?

其中的一個(gè)簡單方案就時(shí)講緩存失效時(shí)間分散開,比如我們可以在原有的失效時(shí)間基礎(chǔ)上增加一個(gè)隨機(jī)值,比如1-5分鐘隨機(jī),這樣每一個(gè)緩存的過期時(shí)間的重復(fù)率就會(huì)降低,就很難引發(fā)集體失效的事件。

我們討論的第二個(gè)問題時(shí)針對同一個(gè)緩存,第三個(gè)問題時(shí)針對很多緩存。

接下來我們將發(fā)表一些自己的緩存高可用實(shí)踐,如《基于云平臺的緩存集群高可用實(shí)踐》,歡迎關(guān)注。

總結(jié)
1、緩存穿透:查詢一個(gè)必然不存在的數(shù)據(jù)。比如文章表,查詢一個(gè)不存在的id,每次都會(huì)訪問DB,如果有人惡意破壞,很可能直接對DB造成影響。
2、緩存失效:如果緩存集中在一段時(shí)間內(nèi)失效,DB的壓力凸顯。這個(gè)沒有完美解決辦法,但可以分析用戶行為,盡量讓失效時(shí)間點(diǎn)均勻分布。

當(dāng)發(fā)生大量的緩存穿透,例如對某個(gè)失效的緩存的大并發(fā)訪問就造成了緩存雪崩。

精彩問答
問題:如何解決DB和緩存一致性問題?

當(dāng)修改了數(shù)據(jù)庫后,有沒有及時(shí)修改緩存。這種問題,以前有過實(shí)踐,修改數(shù)據(jù)庫成功,而修改緩存失敗的情況,最主要就是緩存服務(wù)器掛了。而因?yàn)榫W(wǎng)絡(luò)問題引起的沒有及時(shí)更新,可以通過重試機(jī)制來解決。而緩存服務(wù)器掛了,請求首先自然也就無法到達(dá),從而直接訪問到數(shù)據(jù)庫。那么我們在修改數(shù)據(jù)庫后,無法修改緩存,這時(shí)候可以將這條數(shù)據(jù)放到數(shù)據(jù)庫中,同時(shí)啟動(dòng)一個(gè)異步任務(wù)定時(shí)去檢測緩存服務(wù)器是否連接成功,一旦連接成功則從數(shù)據(jù)庫中按順序取出修改數(shù)據(jù),依次進(jìn)行緩存最新值的修改。

問題:問下緩存穿透那塊!例如,一個(gè)用戶查詢文章,通過ID查詢,按照之前說的,是將緩存的KEY預(yù)先設(shè)置一個(gè)值,,如果通過ID插過來,發(fā)現(xiàn)是預(yù)先設(shè)定的一個(gè)值,比如說是“&&”,那之后的繼續(xù)等待訪問是什么意思,這個(gè)ID什么時(shí)候會(huì)真正被附上用戶所需要的值呢?

我剛說的主要是咱們常用的后面配置,前臺獲取的場景。前臺無法獲取相應(yīng)的key,則等待,或者放棄。當(dāng)在后臺配置界面上配置了相關(guān)key和value之后,那么以前的key &&也自然會(huì)被替換掉。你說的那種情況,自然也應(yīng)該會(huì)有一個(gè)進(jìn)程會(huì)在某一個(gè)時(shí)刻,在緩存中設(shè)置這個(gè)ID,再有新的請求到達(dá)的時(shí)候,就會(huì)獲取到最新的ID和value。

問題:其實(shí)用Redis的話,那天看到一個(gè)不錯(cuò)的例子,雙key,有一個(gè)當(dāng)時(shí)生成的一個(gè)附屬key來標(biāo)識數(shù)據(jù)修改到期時(shí)間,然后快到的時(shí)候去重新加載數(shù)據(jù),如果覺得key多可以把結(jié)束時(shí)間放到主key中,附屬key起到鎖的功能。

這種方案,之前我們實(shí)踐過。這種方案會(huì)產(chǎn)生雙份數(shù)據(jù),而且需要同時(shí)控制附屬key與key之間的關(guān)系,操作上有一定復(fù)雜度。

問題:多級緩存是什么概念呢?

多級緩存就像我今天之前給大家發(fā)的文章里面提到了,將Ehcache與Redis做二級緩存,就像我之前寫的文章 http://www.jianshu.com/p/2cd6ad416a5a 提到過的。但同樣會(huì)存在一致性問題,如果我們需要強(qiáng)一致性的話,緩存與數(shù)據(jù)庫同步是會(huì)存在時(shí)間差的,所以我們在具體開發(fā)的過程中,一定要根據(jù)場景來具體分析,二級緩存更多的解決是,緩存穿透與程序的健壯性,當(dāng)集中式緩存出現(xiàn)問題的時(shí)候,我們的應(yīng)用能夠繼續(xù)運(yùn)行。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/61707.html

相關(guān)文章

  • 緩存穿透、并發(fā)失效同步中斷,最佳實(shí)踐優(yōu)化方案

    摘要:當(dāng)緩存空間滿了,同步失敗,網(wǎng)絡(luò)阻塞,緩存寫失敗等原因,會(huì)出現(xiàn)緩存服務(wù)器上并沒有這個(gè)。這種問題,以前有過實(shí)踐,修改數(shù)據(jù)庫成功,而修改緩存失敗的情況,最主要就是緩存服務(wù)器掛了。而緩存服務(wù)器掛了,請求首先自然也就無法到達(dá),從而直接訪問到數(shù)據(jù)庫。 原文摘自: 緩存穿透、并發(fā)和失效,來自一線架構(gòu)師的解決方案https://community.qingcloud.com/topic/463 在我們...

    Blackjun 評論0 收藏0
  • 緩存穿透、并發(fā)失效、同步中斷最佳實(shí)踐優(yōu)化方案

    摘要:當(dāng)緩存空間滿了,同步失敗,網(wǎng)絡(luò)阻塞,緩存寫失敗等原因,會(huì)出現(xiàn)緩存服務(wù)器上并沒有這個(gè)。這種問題,以前有過實(shí)踐,修改數(shù)據(jù)庫成功,而修改緩存失敗的情況,最主要就是緩存服務(wù)器掛了。而緩存服務(wù)器掛了,請求首先自然也就無法到達(dá),從而直接訪問到數(shù)據(jù)庫。 原文摘自: 緩存穿透、并發(fā)和失效,來自一線架構(gòu)師的解決方案https://community.qingcloud.com/topic/463 在我們...

    qc1iu 評論0 收藏0
  • Redis緩存穿透問題解決方案

    摘要:方案二布隆過濾器攔截布隆過濾器介紹概念布隆過濾器英語是年由布隆提出的。這就是布隆過濾器的基本思想。防緩存穿透的布隆過濾器判斷是否為合法非法則不允許繼續(xù)查庫從緩存中獲取數(shù)據(jù)緩存為空從數(shù)據(jù)庫中獲取緩存空對象參考書籍開發(fā)與運(yùn)維 上周在工作中遇到了一個(gè)問題場景,即查詢商品的配件信息時(shí)(商品:配件為1:N的關(guān)系),如若商品并未配置配件信息,則查數(shù)據(jù)庫為空,且不會(huì)加入緩存,這就會(huì)導(dǎo)致,下次在查詢同...

    AlanKeene 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<