MongoDB副本集功能及節點屬性梳理

来源:https://www.cnblogs.com/xuliuzai/archive/2018/12/16/9683889.html
-Advertisement-
Play Games

副本集的主要功能 副本集是MongoDB高可用的基礎,其主要作用 歸納為以下幾點: (1)高可用,防止設備(伺服器、網路)故障。提供自動FailOver功能。 (2)無需配置高可用性虛擬節點;無論是SQL Server 的AlwaysOn 還是 MySQL 的 MHA方案 都需要有可用性組 或集群的 ...


副本集的主要功能

副本集是MongoDB高可用的基礎,其主要作用 歸納為以下幾點:

(1)高可用,防止設備(伺服器、網路)故障。提供自動FailOver功能。

(2)無需配置高可用性虛擬節點;無論是SQL Server 的AlwaysOn 還是 MySQL 的 MHA方案 都需要有可用性組 或集群的虛擬IP,要求程式連接使用這個虛擬IP。但是MongoDB 副本集不需要  配置虛擬IP,而是當我們在連接字元串中指定replicaSet 參數設置 後,會自動識別查找master節點。這樣 可以省去 DBA 對虛擬高可用IP的配置和管理。另外,還有一點 可以保證  主節點、輔助節點切換 對程式的影響,比如丟數據的影響。就是 程式驅動到每個幾點都預先建立了一個連接,這個連接 會實時監控節點狀態。當主節點切換時,會很快就識別出,這種機制保證了切換對程式的影響。

(3)災難恢復,當發生故障時,可以從其它節點快速恢復。

(4)功能隔離,用於分析、報表,數據挖掘,系統任務等。用於備份。

副本集節點屬性介紹

複製集成員最多50個。參與Primary選舉投票的成員最多7個,其他成員的votes屬性必須設置為0,即不參與投票。

下麵我們對副本集的節點做下梳理。

一般而言,副本集節點有3中類型,主節點(Primary)、輔助節點(Secondary)、見證節點(Arbiter)。

主節點(Primary)

 這個節點也比較容易理解。和其他資料庫上的主節點一樣,可以提供讀寫。再次不再贅述。

見證節點(Arbiter

沒有數據副本,不會成為Primary節點,主要用來選舉投票。

當副本集的節點數據為偶數時,可以考慮添加一個見證節點。

見證節點因為沒有數據,只是投票,所以見證節點需要的資源很小,可以和其他應用公用一臺伺服器,但是不建議將見證節點部署在副本集的主節點或輔助節點節點上。

輔助節點(Secondary)

輔助節點也基本上和其他類型資料庫的輔助節點一樣,可以充當備胎。我們在此主要講一講 輔助節點可以設置的幾個屬性。

設置為優先順序為0的節點

 

優先順序為0的節點的特點

1)不會升級為主節點。但是卻可以投票。

2)此節點正常參與Primary產生的oplog的讀取,進行數據備份和命令執行。

3)此節點可正常參與客戶端對於數據的讀取,進行擔當負載均衡的工作。

4)在write concern 設置中,此節點是可見的,在決定<number>.時,是有用節點。與屬性votes =0 不同。

Priority=0在mongoDB中的解釋就是一個Standby,可投票不可參選,又幹活又負載。對於Priority為0節點的情況,通常作為一個standby,或由於硬體配置較差,設置為0以使用不可能成為主。

此節點在數據多中心時很有用。可以將異地的數據節點添加這種屬性。

隱藏節點(Hidden

 

 

字面上來說,隱藏。這個隱藏式對客戶端的隱藏,客戶端如果要讀取Secondary的數據,永遠無法讀取Hidden節點的數據,因為設置了Hidden的這個節點對於客戶端是透明的,不可見。但是,對於自己的Secondary的群體和Primary來說都是可見的,所以,Hidden依然可以投票,依然要按照oplog進行命令的複製,只是,不參與負載了。

Hidden屬性的前提是必須是一個Priority=0的節點,所以會具備一些優先順序=0的特點。

1)Hidden節點不能被選為主(Priority為0),並且對Driver不可見。

2)但在Hidden節點上,可做一些數據備份、離線計算的任務,不會影響複製集的服務

3)隱藏節點成員建議總是將其優先順序設置為0(priority 0)

4)由於對Driver不可見,因此不會作為read preference節點,隱藏節點可以作為投票節點

5)在分片集群當中,mongos不會同隱藏節點交互。

延遲節點(Delayed

 

延遲比較容易理解,代表此節點的數據與Primary的數據有一定的遲延,通過設定一個遲延的屬性來確定。

1)此節點必須是一個Priority=0且為Hidden的節點。

2)此節點雖然又遲延又Hidden,但是還是可以投票。

3)延遲單位設置為秒。

節點屬性如下:

{
   "_id" : <num>,
   "host" : <hostname:port>,
   "priority" : 0,
   "slaveDelay" : <seconds>,
   "hidden" : true
}

 非投票節點(votes:0)

我們在前面已經接受了,一個副本集最多有7個投票節點,如果還有其它的節點,需要設置為非投票節點。

非投票節點擁有數據副本,但是不參與投票。另外,非投票節點,其 priority 必須設置為 0。

 


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

-Advertisement-
Play Games
更多相關文章
  • 安裝swat swat是一個圖形化的samba管理軟體,可以幫助不熟悉的人去靈活的配置samba服務, 1、安裝swat [root@localhost wj]#yum install -y samba-swat Dependency Updated: libsmbclient.i686 0:3.6 ...
  • { 個人心得: 嵌入式底層重要的是在CPU(各種架構)或SOC基礎上,利用u-boot初始化系統,並啟動OS,建立實時多任務環境、文件系統等,再根據功能要求設計上層程式;而對硬體的需有足夠掌握。 } 1 cmd命令 1.1 常用命令 pwd、ls、cd、mkdir(文件操作:touch、cp、mv、 ...
  • inotify簡介: inotify是一種強大的、細粒度的、非同步的文件系統事件監控機制,linux內核從2.6.13起,加入了inotify支持,通過inotify可以監控文件系統添加、刪除、修改、移動等各種事件,利用這個內核介面,第三方軟體就可以監控文件系統下文件的各種變化情況,而inotify- ...
  • 大家都知道數據非常重要的,需要經常備份,如果備份了,但無法恢復還原,那就證明你備份的很失敗,所有當我們備份了數據需要檢查是否備份完整,是否可用可恢復。以下為一個企業案例: 某公司里有一臺Web伺服器,裡面的數據很重要,但是如果硬碟壞了,數據就會丟失,現在領導要求你把數據在其他機器上做一個周期性定時備 ...
  • 在內核初始化完成之後, 記憶體管理的責任就由伙伴系統來承擔. 伙伴系統基於一種相對簡單然而令人吃驚的強大演算法. Linux內核使用二進位伙伴演算法來管理和分配物理記憶體頁面, 該演算法由Knowlton設計, 後來Knuth又進行了更深刻的描述. 伙伴系統是一個結合了2的方冪個分配器和空閑緩衝區合併計技術的 ...
  • Centos7 firewall開放3306埠 1. 查看防火牆狀態 2. 關閉防火牆firewall 3. 開啟埠 4. 重啟防火牆 5. 常用命令介紹 ...
  • 無人值守安裝可以大大縮短安裝系統的時間。我在虛擬機測試成功。 先給文件鏈接https://files.cnblogs.com/files/sishenzaixian/%E8%87%AA%E5%8A%A8%E5%AE%89%E8%A3%85.zip。 這裡先上xp自動應答文件——unattend.tx ...
  • 一 說明 這個是我第一篇博客,所以我想放上原創的東西,儘管我一直都很擔心自己寫得太low,但是總要學會嘗試,學會改變自己,相信自己。在寫這個腳本時,由於我接觸LInux不是很多,能力有限,僅僅是為了讓自己心情好點,可以說只是為了完成任務,並沒有考慮其中比如代碼重覆,註釋不完整等諸多問題。這是9月份做 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...