久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

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

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

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

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

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

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

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

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

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

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

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

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

50 (1)

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

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

  二. 緩存同步分析

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

51 (1)

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

52 (1)

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

53 (1)

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

54 (1)

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

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

55 (1)

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

  三. 緩存同步解決思路

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

56 (1)

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

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

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

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

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

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

2023-05-08 13:41:00
快速通道