Redis (四) 爲什麼要使用Pipeline以及redis的主從同步

使用PIpeline的好處

  1. pipeline和linux的管道相似
cat /tmp/redisTest.txt | redis-cli -h [127.0.0.1] -p [6379] --pipe

一次性傳入,批量執行

  • redis基於請求/響應模型,節省請求處理需要一一應答
  • PipeLine批量執行指令,節省IO往返的時間
  • 有順序依賴的指令建議分批發送

Redis的同步機制

主從同步原理
在這裏插入圖片描述
一個master進行寫入操作,多個salve進行讀取操作

  • 全量同步
  1. Salve發送sync命令到maste
  2. master啓動一個後臺進程,將redis中的數據快照保存到文件中
  3. master將保存數據快照期間接收到的寫命令緩存起來
  4. master完成寫文件操作後,將該文件發送給salve
  5. 使用新的AOF文件替換掉舊的AOF文件
  6. Master將期間手機的增量寫命令發送給salve端
  • 增量同步
  1. master接收到用戶的操作指令後,判斷是否需要傳播到Slave
  2. 將操作記錄追加到AOF文件
  3. 將操作傳播到其他Slave
    1. 對齊主從庫;
    2. 往響應緩存寫入指令
  4. 將緩存中的數據發送給Slave

Redis Sentinel

解決主從同步Master宕機後的主從切換問題

  • 監控:檢查主從服務器是否運行正常
  • 提醒:通過API向管理員或者其他應用程序發送故障通知
  • 自動故障嫌疑:主從切換
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章