Redis主從複製

来源:http://www.cnblogs.com/jiekzou/archive/2016/04/10/5372360.html
-Advertisement-
Play Games

大家可以先看這篇文章ASP.NET Redis 開發對Redis有個初步的瞭解 Redis的主從複製功能非常強大,一個master可以擁有多個slave,而一個slave又可以擁有多個slave,如此下去,形成了強大的多級伺服器集群架構. 實現步驟如下: 1.在Windows某個磁碟上創建兩個目錄, ...


大家可以先看這篇文章ASP.NET Redis 開發對Redis有個初步的瞭解

Redis的主從複製功能非常強大,一個master可以擁有多個slave,而一個slave又可以擁有多個slave,如此下去,形成了強大的多級伺服器集群架構.

實現步驟如下:

1.Windows某個磁碟上創建兩個目錄,例如; MasterRedis(存儲的是Master服務) SlaveRedis(存儲的是Slave服務).

2.Master服務中的配置文件redis.conf修改 :bind 127.0.0.1.

3.Slave服務中的配置文件redis.conf修改: 

      port 6381(服務埠號要分開)

      bind 127.0.0.1

      slaveof 127.0.0.1 6379 (設置masterHost以及Port

4.分別啟動Master服務與Slave服務。

註意到,當我啟動master,然後啟動一個slave的時候,可以發現slave上: 

 

會發送一個SYNC請求,從Master上面進行相應,而且它支持自動重連,

即當master掉線的情況下,它會處於等待請求的狀態。

Master上:

 

第一次SlaveMaster同步的實現是:SlaveMaster發出同步請求,Masterdumprdb文件,然後將rdb文件全量傳輸給slave,然後Master把緩存的命令轉發給Slave,初次同步完成。第二次以及以後的同步實現是:Master將變數的快照直接實時依次發送給各個Slave。不管什麼原因導致SlaveMaster斷開重連都會重覆以上過程。Redis的主從複製是建立在記憶體快照的持久化基礎上,只要有Slave就一定會有記憶體快照發生。雖然Redis宣稱主從複製無阻塞,但由於Redis使用單線程服務,如果Master快照文件比較大,那麼第一次全量傳輸會耗費比較長時間,且文件傳輸過程中Master可能無法提供服務,也就是說服務會中斷 

Redis數據快照

數據快照的原理是將整個Redis記憶體中的所有的數據遍歷一遍存儲到一個擴展名為rdb的數據文件中,通過save命令

可以調用這個過程。數據快照配置如下:

Save 900 1

Save 300 10

Save 60 10000

以上在redis.conf中的配置指出在多長時間內,有多少次更新操作,就將數據同步到數據文件中,這個可以多個條件進行配合,上面的含義是900秒後有一個key發生改變就執行save,300秒後有10key發生改變就執行save,60秒有10000key發生改變就執行save.

數據快照的缺點是持久化之後如果出現系統宕機則會丟失一段數據,因此增加了另外一種追加式的操作日誌記錄,叫append only file,其日誌文件以aof結尾,我們稱為aof文件,要開啟aof日誌的記錄,需要在配置文件中進行如下配置: appendonly yes

Appendonly配置不開啟,可能在斷電時導致一段時間的數據丟失,因為redis本身同步數據文件時按save條件來同步的,所以有的數據會在一段時間內只存在於記憶體中。

Appendfsync no/always/everysec

no:表示等操作系統進行數據緩存同步到磁碟。性能最好,持久化沒有保障。

Always:表示每次更新操作後手動調用fsync()將數據寫到磁碟.每次收到寫命令就立即強制寫入磁碟,最慢的,但是保障完全的持久化。

Everysec:表示每秒同步一次.每秒鐘強制寫入磁碟一次,在性能和持久化方面做了很好的折中。

為了定時減小AOF文件的大小,Redis2.4以後增加了自動的bgrewriteaof的功能,Redis會選擇一個自認為負載低的情況下執行bgrewriteaof,這個重寫AOF文件的過程是很影響性能的。解決方案:Master關閉Save功能,關閉AOF日誌功能,以求達到性能最佳。Slave開啟Save並開啟AOF日誌功能,並開啟bgrewriteaof功能,不對外提供服務,這樣Slave的負載總體上會高於Master負載,但是Master性能達到最好.

Bgrewriterof內部實現:

 1.Redis通過fork一個子進程,遍曆數據,寫入新臨時文件

 2.父進程繼續處理client請求,子進程繼續寫臨時文件。

 3.父進程把新寫入的AOF寫在緩衝區。

 4.子進程寫完退出,父進程接收退出消息,將緩衝區AOF寫入臨時文件。

 5.臨時文件重命名成appendonly.aof,原來文件被覆蓋,整個過程完成。

Redis數據恢復

Redis伺服器掛掉以後,重啟時將按以下優先順序恢複數據到記憶體:

1.如果只配置了AOF,重啟時載入AOF文件恢複數據。

2.如果同時配置了RBDAOF,啟動時只載入AOF文件恢複數據。

3.如果只配置了RDB,啟動時將載入dump文件恢複數據。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Mask屬性介紹 Mask平時用的最多的是masksToBounds 吧. 其實除此以外Mask使用場景很多,看完之後你會發現好真是好用的不要不要的... 先來瞭解下Mask屬性到底是什麼? Mask 英文解釋是蒙板/面罩,平時我們稱為蒙層. 在蘋果官方文檔里如下圖,意思是Mask是一個可選的Lay ...
  • 今天我們介紹的是Checkbox多選框: 1.Activity 2.xml文件如下: 3.效果圖如下: ...
  • 在移動應用滿天飛的時代,隨著移動支付的盛行,很多應用中都集成了支付功能。之前的支付一直不是我負責,近期這個項目我負責訂單模塊少不了要做支付,每每提起支付就覺得怕怕,覺得很難,但當真正做的時候卻遠遠沒有想象中的那麼難。支付寶的SDK提供了demo,我們只需要配置好一些基本信息,這個demo就可以正常支 ...
  • 今天我們的主要內容就是安卓的主要幾個基礎的佈局方式。(主要佈局如下:) 1.線性佈局(LinerLayout) 2.相對佈局(RelativeLayout) 3.表格佈局(TableLayout) 4.網格佈局(GridLayout) 5.絕對佈局(AbsoluteLayout) 6.幀佈局(Fra ...
  • IOS 瀑布流UICollectionView實現 在實現瀑布流之前先來看看瀑布流的雛形(此方法的雛形 UICollectionView) 對於UICollectionView我們有幾點註意事項 它和tableView不一樣,ContentView的內容完全需要我們自己去添加。 它與tablevie ...
  • 最近項目中需要用到一些視圖的某些邊界設置為圓角,比如指定一個長方形view,需要設置其左邊為圓形,所以就封裝一個類來實現指定邊界的圓角 1,首先創建一個繼承於UIView的分類(由於項目中我需設置一個button的圓角, 所以命名為Btn) 2.在介面文件中設置介面 這裡參數:distance 為需 ...
  • 在上一篇中我們雖然成功進入了保護模式,但是並沒有體驗到保護模式帶給我們的便利。其實在保護模式下定址空間可以達到4GB,實模式下1MB的定址能力差得太遠了。那麼下麵,我們就把程式稍作修改,體驗一下它對超過1MB記憶體的訪問能力。 我們來試驗一下讀寫大地址記憶體。在前面程式的基礎上,新建一個段,這個段以5M ...
  • 保持listview滑動的位置,一般用在增加listview子item中佈局的評論或者退出當前活動,再次進入繼續閱讀時。 利用ListView.getFirstVisiblePosition()來獲取當前可見的第一個Item的position,在滾動監聽中設置 其中存儲position和scroll ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...