java面試寶典 redis篇 高可用和持久化

高可用

哨兵模式

image.png

基于主從模式(一主多從),主服務器提供寫服務,從服務器同步主服務器,從服務器可提供讀服務,哨兵(可多個節(jié)點實現(xiàn)高可用)監(jiān)控所有服務,實現(xiàn)故障時自動主從切換

缺點: 只提供高可用并沒有提高redis的讀寫能力,存在主從切換時瞬斷問題

高可用集群模式

redis單機支持10萬并發(fā), Redis集群水平擴展能突破這個并發(fā)數(shù)

image.png

各個集群模式數(shù)據(jù)獨立, Jedis(Redis官方推薦的Java連接開發(fā)工具)通過算法計算緩存key落在哪個集群,再由這個集群提供服務,算法參考 java面試寶典 redis篇 一致性hash算法, 假如集群主服務器掛了,對應的服務唯一碼也會在列表中去掉,請求也就不會往故障集群發(fā)送,這就解決了主從切換瞬斷的問題

持久化

RDB

RDB持久化是指在指定的時間間隔內將內存中的數(shù)據(jù)集快照寫入磁盤

三種觸發(fā)模式

  1. save觸發(fā)方式
    該命令會阻塞當前Redis服務器,執(zhí)行save命令期間,Redis不能處理其他命令,直到持久化過程完成為止, 這種方式顯然不可取。
  2. bgsave觸發(fā)方式
    執(zhí)行該save命令時,Redis會在后臺異步進行快照操作, 默認采用這種方式
  3. 自動觸發(fā)
    自動觸發(fā)是由我們的配置文件來完成的。在redis.conf配置文件中,我們可以去設置

優(yōu)點:

(1)RDB快照是一次全量備份,存儲的是內存數(shù)據(jù)的二進制序列化形式,存儲上非常緊湊,非常適合用于進行備份和災難恢復。
(2)RDB 在恢復大數(shù)據(jù)集時的速度比 AOF 的恢復速度要快。

缺點:

備份是用子線程備份, 父進程修改內存子進程不會反應出來,所以在快照持久化期間修改的數(shù)據(jù)不會被保存,可能丟失數(shù)據(jù)。

AOF

redis會將每一個收到的寫命令都通過write函數(shù)追加到文件中。通俗的理解就是日志記錄。

由于持久化文件會變的越來越大, redis會會fork出一條新進程來將文件重寫, 重寫aof文件的操作,并沒有讀取舊的aof文件,而是將整個內存中的數(shù)據(jù)庫內容用命令的方式重寫了一個新的aof文件,這點和快照有點類似。

二種觸發(fā)模式

  1. 同步觸發(fā),數(shù)據(jù)可靠,但是會有延遲
  2. 異步觸發(fā),沒有延遲,可能有數(shù)據(jù)丟失

優(yōu)點:

AOF日志文件的命令通過非常可讀的方式進行記錄,這個特性非常適合做災難性的誤刪除的緊急恢復。比如某人不小心用flushall命令清空了所有數(shù)據(jù),只要這個時候后臺rewrite還沒有發(fā)生,那么就可以立即拷貝AOF文件,將最后一條flushall命令給刪了,然后再將該AOF文件放回去,就可以通過恢復機制,自動恢復所有數(shù)據(jù)

缺點:

(1)對于同一份數(shù)據(jù)來說,AOF日志文件通常比RDB數(shù)據(jù)快照文件更大

(2)以前AOF發(fā)生過bug,就是通過AOF記錄的日志,進行數(shù)據(jù)恢復的時候,沒有恢復一模一樣的數(shù)據(jù)出來。

更多demo請關注

springboot demo實戰(zhàn)項目
java 腦洞
java 面試寶典
開源工具

公眾號

五分鐘了解前沿技術,大數(shù)據(jù),微服務,區(qū)域鏈,提供java前沿技術干貨,獨立游戲制作技術分享

五分鐘技術

如果這篇文章對你有幫助請給個star


image.png
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,572評論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,071評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,409評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,569評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,360評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 54,895評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,979評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,123評論 0 286
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 48,643評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,559評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,742評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,250評論 5 356
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 43,981評論 3 346
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,363評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,622評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,354評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,707評論 2 370