redis數(shù)據(jù)一致性的實(shí)現(xiàn)示例
前言
所謂的redis數(shù)據(jù)一致性即當(dāng)進(jìn)行修改或者保存、刪除之后,redis中的數(shù)據(jù)也應(yīng)該進(jìn)行相應(yīng)變化,不然用戶再次查詢的時候很可能查詢出已經(jīng)刪除過的臟數(shù)據(jù)。
一、緩存一致的必要性
還是接上篇來說,我們已經(jīng)解決了redis緩存穿透的問題(簡單解決方案,可以再次優(yōu)化),但是使用redis的時候緩存一致性的問題我們也需要著重考慮,例如:保存了一個新用戶之后,就應(yīng)該同時在redis緩存中也插入該條數(shù)據(jù),更新了某條數(shù)據(jù)在緩存中也應(yīng)該同步更新,而redis默認(rèn)的做法是:當(dāng)你不去設(shè)置的時候redis中存放的一值是你之前存放的數(shù)據(jù),只有在重啟服務(wù)器的時候數(shù)據(jù)才會同步,顯然這是非常不可取的,如果是這樣的話豈不是每時每刻都要重啟服務(wù)器,那將是多么大的災(zāi)難!
二、業(yè)務(wù)場景
這里我只說一個場景吧,其他場景都是一樣的處理辦法,場景為:假設(shè)我們將用戶數(shù)據(jù)放入到redis中,此時有新用戶注冊,在數(shù)據(jù)庫中會插入一條新數(shù)據(jù),與此同時要在redis中也插入該條數(shù)據(jù),以便于下次查詢的時候顯示最新數(shù)據(jù)。
我們先來看一下默認(rèn)不使用任何處理的情況下redis是否會為我們做一致性操作,現(xiàn)在我的測試數(shù)據(jù)庫中有18條用戶數(shù)據(jù),此時我們啟動系統(tǒng)后注冊插入第19條數(shù)據(jù)后看下redis中是否有19條。
經(jīng)過注冊之后我現(xiàn)在給數(shù)據(jù)庫中插入了第19條數(shù)據(jù)
接著我們還是使用上篇提到過的查詢緩存的方法來獲取下所有信息,我們直接來看第最后一條,可以看到最后是潤青而不是十九,所以redis默認(rèn)是沒有替我們做緩存一致操作的。
三、緩存一致性實(shí)現(xiàn)(方案1)
其實(shí),要想實(shí)現(xiàn)一致性很簡單,當(dāng)我們在進(jìn)行插入操作之后,我們把該條數(shù)據(jù)取出來同時保存到redis緩存中去,這樣再次查詢緩存的時候我們也可以看到新的數(shù)據(jù),代碼如下:
需要注意的是:我這里直接是調(diào)用JPA的findAll(),其實(shí)更好的做法是根據(jù)id去更新剛插入的那一條,這樣效率才高,這里只是演示如何實(shí)現(xiàn),接著再來注冊一條新數(shù)據(jù),看看是否可以在緩存中同時看到:新插入的數(shù)據(jù)id為29,我們來看下緩存是否存在該條新數(shù)據(jù)
四、redis緩存一致性實(shí)現(xiàn)(方案2)
定期清除redis中的數(shù)據(jù),例如設(shè)置一個定時任務(wù),每當(dāng)一個小時的時候就會清除redis中的數(shù)據(jù),也就是讓redis中的數(shù)據(jù)失效,然后再次保存、刪除的時候之前的 redis中的數(shù)據(jù)已經(jīng)不存在,所以相當(dāng)于是將數(shù)據(jù)重新設(shè)置到redis中去,所以可以保證數(shù)據(jù)的一致性。
到此這篇關(guān)于redis數(shù)據(jù)一致性的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)redis數(shù)據(jù)一致性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
- Redis緩沖區(qū)溢出是指Redis緩沖區(qū)被寫入的數(shù)據(jù)超過了它的容量,導(dǎo)致數(shù)據(jù)無法存儲或被覆蓋。造成緩沖區(qū)溢出的原因可能是快速寫入大量數(shù)據(jù)、緩沖區(qū)未及時刷新或Redis服務(wù)器配置不當(dāng)?shù)取?/div> 2023-04-04
Mac中Redis服務(wù)啟動時錯誤信息:NOAUTH Authentication required
這篇文章主要介紹了Mac中使用Redis服務(wù)啟動時錯誤信息:"NOAUTH Authentication required"問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08最新評論