千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  應(yīng)聘面試  >  Java面試題  > 如何保證Redis緩存與數(shù)據(jù)庫的同步?你確定不來看看這道高頻面試題

如何保證Redis緩存與數(shù)據(jù)庫的同步?你確定不來看看這道高頻面試題

來源:千鋒教育
發(fā)布人:syq
時間: 2022-10-11 17:24:06 1665480246

  今天小千要給大家分享一道關(guān)于數(shù)據(jù)庫緩存同步的面試題,希望通過這道面試題可以幫助大家搞定面試官。

如何保證Redis緩存與數(shù)據(jù)庫的同步

  一. 數(shù)據(jù)緩存

  數(shù)據(jù)緩存在高并發(fā)的系統(tǒng)設(shè)計中很常見,因為Redis確實能有效地解決數(shù)據(jù)庫和磁盤的I/O瓶頸,當一個高并發(fā)接口要查詢低頻修改的數(shù)據(jù)時,我們都建議用Redis實現(xiàn)數(shù)據(jù)緩存。

  一般的緩存實現(xiàn)思路如下:

50 (1)

  其實緩存的實現(xiàn)思路很簡單,這個思路能保證只有第一次查詢的是數(shù)據(jù)庫,后續(xù)的訪問查詢的都是Redis,這樣不僅提高了接口的訪問效率,還在一定程度上實現(xiàn)了數(shù)據(jù)庫的讀寫分離。

  那么現(xiàn)在問題來了,如果我們的數(shù)據(jù)庫數(shù)據(jù)發(fā)生了變化,Redis怎么保證和數(shù)據(jù)庫里的數(shù)據(jù)一致呢?這個問題就是我們今天要探討的緩存同步問題。

  二. 緩存同步分析

  緩存同步這個思路相信大家很快就能搞清楚,大概思路如下:

51 (1)

  當我們對業(yè)務(wù)庫做了修改,我們可以通過同步更新的方式去同步,也可以通過暴力刪除Redis的方式去同步。因為刪除Redis,會再次查詢數(shù)據(jù)庫的最新數(shù)據(jù),這樣就可以達成同步的目的。但不管你使用哪種方式,都會存在一些意想不到的問題,如下:

52 (1)

  先寫數(shù)據(jù)庫,再更新Redis,上圖中演示了一種極端情況,按照時間軸的發(fā)展,數(shù)據(jù)庫里的最新值是8,但Redis中的最新值是9,并沒有一致。

53 (1)

  如果我們先更新Redis,再寫數(shù)據(jù)庫,按照時間軸,Redis里的最新值是8 ,數(shù)據(jù)庫里的最新值是9,還是沒有保持一致。

54 (1)

  先寫數(shù)據(jù)庫,再刪Redis,這也不行。

  如上圖,當數(shù)據(jù)庫里的值為9,然后再刪Redis。假如這時有一個讀線程來了,發(fā)現(xiàn)Redis數(shù)據(jù)沒了,這個讀線程立即查詢數(shù)據(jù)庫,讀到的就是9。然而不巧的是另外一個寫線程將數(shù)據(jù)庫改為8 ,也就是說數(shù)據(jù)庫最新為8,結(jié)果緩存發(fā)生在更新數(shù)據(jù)庫之后,緩存最新的值就是9,還是不能一致。

55 (1)

  如果我們先刪Redis再寫數(shù)據(jù)庫,寫線程上來把Redis刪了,讀線程立即讀數(shù)據(jù)庫,比如讀到的舊數(shù)據(jù)是8,然后寫線程再改數(shù)據(jù)庫為9,這時數(shù)據(jù)庫最新為9,但Redis中的值是8,結(jié)果還是不一致。

  三. 緩存同步解決思路

  上面分析了四種情況,它們在極端情況下都不能保證數(shù)據(jù)庫和Redis的雙寫一致性,那到底為什么不能呢?問題到底出在哪里了,其實原因很簡單,就是我們不能保證數(shù)據(jù)庫和redis操作的原子性!在我們進行這兩個操作時,總是有別的線程在破壞數(shù)據(jù),所以才會出現(xiàn)各種問題,那怎么解決呢?我們先來看看下面的解決思路:

56 (1)

  這個思路大致是這樣的,寫線程只負責改數(shù)據(jù)庫,不要去參與Redis同步的問題,Redis同步交給一個嚴格順序的pipeline解決。這個pipeline的流程是,當數(shù)據(jù)庫發(fā)生數(shù)據(jù)變化會立即產(chǎn)生binlog日志,我們可以借助阿里的canal組件去監(jiān)聽binlog,同時解析binlog,將解析的結(jié)果以消息的方式發(fā)送給MQ。MQ要保證嚴格順序,再通過消費者去消費消息,將最新的數(shù)據(jù)覆蓋更新到Redis,到此就能解決緩存的同步。

  現(xiàn)在你對數(shù)據(jù)庫和Redis緩存的同步問題還有疑惑嗎?如果還有別的問題,請關(guān)注我們吧,干貨不斷哦。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學 138****2860 剛剛成功領(lǐng)取
王同學 131****2015 剛剛成功領(lǐng)取
張同學 133****4652 剛剛成功領(lǐng)取
李同學 135****8607 剛剛成功領(lǐng)取
楊同學 132****5667 剛剛成功領(lǐng)取
岳同學 134****6652 剛剛成功領(lǐng)取
梁同學 157****2950 剛剛成功領(lǐng)取
劉同學 189****1015 剛剛成功領(lǐng)取
張同學 155****4678 剛剛成功領(lǐng)取
鄒同學 139****2907 剛剛成功領(lǐng)取
董同學 138****2867 剛剛成功領(lǐng)取
周同學 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
面向?qū)ο缶幊痰奶卣魇鞘裁?請解釋每個特征

答案:面向?qū)ο缶幊痰奶卣靼ǎ悍庋b(Encapsulation):封裝是將相關(guān)的數(shù)據(jù)和方法組合在一起形成類的機制。它可以隱藏內(nèi)部實現(xiàn)細節(jié),只暴露必要的...詳情>>

2023-07-18 13:56:00
容器是什么?如何理解容器

  容器(Container)是一個廣泛的概念,指的是一種可以容納其他元素或?qū)ο蟮臄?shù)據(jù)結(jié)構(gòu)或抽象概念。在計算機科學中,容器的概念經(jīng)常出現(xiàn)在數(shù)據(jù)結(jié)...詳情>>

2023-05-08 13:41:00