MongoDB教程(六):mongoDB复制副本集

news2024/12/24 0:19:36

💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快!

文章目录

      • 引言
      • 一、MongoDB 复制副本集概述
        • 1.1 复制副本集的优势
      • 二、复制副本集的架构
        • 2.1 PSS 模式
        • 2.2 PSA 模式
      • 三、复制副本集的配置步骤
        • 3.1 环境准备
        • 3.2 安装 MongoDB
        • 3.3 创建配置文件
        • 3.4 启动 MongoDB 实例
        • 3.5 初始化副本集
        • 3.6 验证副本集状态
      • 四、故障转移测试
      • 五、实际应用中的考虑因素

引言

MongoDB 的复制副本集(Replica Set)是 MongoDB 实现高可用性和数据冗余的重要机制。本文将详细介绍 MongoDB 复制副本集的工作原理、架构、配置步骤,并通过一个详细的案例来说明如何搭建一个基本的 MongoDB 复制副本集。

一、MongoDB 复制副本集概述

MongoDB 的复制副本集是一组维护相同数据集合的 mongod 实例,这些实例协同工作以确保数据的高可用性和冗余。副本集包括一个主节点(Primary)和多个从节点(Secondary),所有客户端的写操作都通过主节点进行,而从节点则从主节点复制数据以保持数据的一致性。当主节点出现故障时,副本集会自动从从节点中选举出一个新的主节点,从而确保服务的连续性。

1.1 复制副本集的优势

高可用性和故障转移:自动选举新的主节点,确保服务不中断。
数据冗余:通过在不同节点上存储数据副本,提高数据的可靠性和安全性。
读写分离:从节点可以处理读操作,提高系统的读取能力。
灾难恢复:在数据中心故障时,可以快速切换到异地备份。

二、复制副本集的架构

2.1 PSS 模式

PSS 模式是 MongoDB 推荐的复制副本集模式,由一个主节点和两个从节点组成(Primary+Secondary+Secondary)。此模式始终提供数据集的两个完整副本,保证了数据的高可用性。

2.2 PSA 模式

PSA 模式由一个主节点、一个从节点和一个仲裁者节点组成(Primary+Secondary+Arbiter)。仲裁者节点不存储数据副本,也不参与读写操作,仅用于在选举过程中提供投票。此模式在资源有限时很有用,因为它仅提供一个完整的数据副本,同时减少了资源消耗。

三、复制副本集的配置步骤

3.1 环境准备

首先,需要准备至少三台服务器或虚拟机来部署 MongoDB 实例。在本文的案例中,我们将使用同一台机器上的不同端口来模拟三个不同的 MongoDB 实例。

3.2 安装 MongoDB

确保 MongoDB 已安装在所有服务器上,并配置好环境变量。在本文的案例中,我们假设 MongoDB 已安装在 /data/program/software/mongodb 目录下。

3.3 创建配置文件

为每个 MongoDB 实例创建独立的配置文件,指定不同的端口、数据目录和日志文件路径。以下是三个实例的配置文件示例:

# mongod1.conf  
dbpath=/data/db1  
logpath=/data/db1/mongod.log  
port=27017  
bindIp=0.0.0.0  
replSet=rs0  
fork=true  
logAppend=true  
  
# mongod2.conf  
dbpath=/data/db2  
logpath=/data/db2/mongod.log  
port=27018  
bindIp=0.0.0.0  
replSet=rs0  
fork=true  
logAppend=true  
  
# mongod3.conf  
dbpath=/data/db3  
logpath=/data/db3/mongod.log  
port=27019  
bindIp=0.0.0.0  
replSet=rs0  
fork=true  
logAppend=true
3.4 启动 MongoDB 实例

使用上述配置文件启动三个 MongoDB 实例:

mongod --config /path/to/mongod1.conf  
mongod --config /path/to/mongod2.conf  
mongod --config /path/to/mongod3.conf
3.5 初始化副本集

连接到其中一个 MongoDB 实例(例如,连接到 27017 端口的主机),并初始化副本集:

mongo --port 27017  
rs.initiate({  
  _id: "rs0",  
  members: [  
    { _id: 0, host: "localhost:27017" },  
    { _id: 1, host: "localhost:27018" },  
    { _id: 2, host: "localhost:27019" }  
  ]  
})
3.6 验证副本集状态

使用 rs.status() 命令来检查副本集的状态,确保所有成员都健康且已正确配置。

rs.status()

四、故障转移测试

为了验证副本集的故障转移功能,可以模拟主节点故障:

  1. 停止主节点的 MongoDB 实例。
  2. 等待一段时间,观察副本集是否自动选举出一个新的主节点。
  3. 再次执行 rs.status() 命令,查看新的主节点和副本集的状态。

五、实际应用中的考虑因素

  1. 网络延迟:副本集节点之间的网络延迟会影响数据同步的效率和故障转移的速度。
  2. 数据一致性:根据应用的需求,合理配置读偏好(Read Preference)来控制从哪个节点读取数据,以满足不同的一致性要求。
  3. 资源分配:为每个节点分配足够的资源,包括 CPU、内存和存储,以确保它们能够正常运行和处理数据。

喜欢博主的同学,请给博主一丢丢打赏吧↓↓↓您的支持是我不断创作的最大动力哟!感谢您的支持哦😘😘😘
打赏下吧

💝💝💝如有需要请大家订阅我的专栏【MongoDB系列】哟!我会定期更新相关系列的文章
💝💝💝关注!关注!!请关注!!!请大家关注下博主,您的支持是我不断创作的最大动力!!!

MongoDB相关文章索引文章链接
MongoDB教程(一):Linux系统安装mongoDB详细教程MongoDB教程(一):Linux系统安装mongoDB详细教程
MongoDB教程(二):mongoDB引用shellMongoDB教程(二):mongoDB引用shell
MongoDB教程(三):mongoDB用户管理MongoDB教程(三):mongoDB用户管理
MongoDB教程(四):mongoDB索引MongoDB教程(四):mongoDB索引
MongoDB教程(五):mongoDB聚合框架MongoDB教程(五):mongoDB聚合框架

❤️❤️❤️觉得有用的话点个赞 👍🏻 呗。
❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄
💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍
🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1929505.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

React 速通笔记

前言 最近刚学完 React,想着把笔记分享给大家,本笔记特别适合从事后端想要学习前端的人。我看视频是黑马最新的 React 视频(黑马程序员前端React18入门到实战视频教程,从reacthooks核心基础到企业级项目开发实战(B站评…

Windows 2012安装之实现远程连接

新建虚拟机 点击稍后安装操作系统 点击Microsoft Windows(W) 选择Windows Server 2012 设置虚拟机名称、安装位置 选择你的电脑核数 点击编辑虚拟机设置 点击CD/DVD(SATA) 使用ISO映像文件(M) 配置完之后点击确定 然后开启虚拟机 下一步: 点击现在安装&#xff1a…

51单片机(STC8H8K64U/STC8051U34K64)_RA8889驱动大屏_硬件SPI4_参考代码(v1.3)

单片机实际不限,这里采用的STC最新、主推的型号,比如STC8H8K64U、STC8051U34K64进行实验测试,您可以换用不同型号。目前测试这两个系列,显示速度均相当不错,软件设计也是极为简单。各篇文章下方均提供源码供参考下载。…

Java 反射用法和8道练习题

目录 一、什么是反射二、反射的核心接口和类三、测试代码 Bean 类和目录结构Person 类代码目录结构 四、获取 Class 对象五、获取构造方法 Constructor 并使用六、获取成员变量 Field 并使用七、获取成员方法 Method 并使用八、练习1. 使用反射获取String类的所有公有方法&…

在python里构建你的投资组合portfolio--最好用的pandas零基础

有人可能觉得软件数据分析门槛很高,自学也坚持不下来, 其实分解成一个小的功能和任务,对零基础自学者非常有帮助。 今天用python中最好用的数据分析包pandas为例: 用最简单的代码完成全流程 构建投资组合 → 获取数据 → 进行分…

均匀性大于98%均匀光源积分球

在光学技术的浩瀚星空中,均匀光源积分球犹如一颗璀璨的明珠,以其卓越的均匀性能,照亮了科研、检测、照明等多个领域的探索之路。当谈及均匀性超过98%的积分球时,我们不禁要深入其内部,探索这一科技奇迹背后的原理与应用…

phenocycler发现免疫治疗反应关键的肿瘤微环境区域

T 细胞介导的抗原特异性反应对于有效的免疫监视至关重要。然而T细胞如何进入肿瘤微环境并操纵局部组织微环境来实现效应器功能,以及这些局部的细胞结构如何对T细胞疗法或者其他免疫治疗做出反应仍然不清楚。近期来自斯坦福大学的研究者利用小鼠模型和临床患者样本&a…

10位工程师做SW大装配设计工作站怎么选

在日益复杂的工程环境中,SolidWorks(SW)作为一款全球装机量较大的三维设计、动画、仿真模拟计算软件,已成为工程师们不可或缺的工具。 对于涉及大型装配设计的项目,选择一款合适的SW工作站显得尤为关键。在选择SW大装…

【0630开发者活动】机器学习算法在存内计算芯片WTM2101上的部署

前言 WTM2101芯片是由Witin知存科技开发的高性能存内计算芯片,专为加速AI计算设计,如图1.1所示。存内计算作为一种革命性技术,其主要优势在于将计算功能直接集成到存储器中,从而显著减少数据在芯片内部的传输距离,降低…

【学术会议征稿】2024年第三届信息学,网络与计算技术国际学术会议(ICINC2024)

2024年第三届信息学,网络与计算技术国际学术会议(ICINC2024) 2024 3rd International Conference on Informatics,Networking and Computing (ICINC 2024) 2024年第三届信息学,网络与计算技术国际学术会议(ICINC2024)将于2024年10月25-27日于中国郑州召…

Django任务管理:项目定时执行及简单管理界面

1、用django-admin命令创建一个Django项目 django-admin startproject task_manager 2、进入到项目下用命令创建一个应用 cd task_manager python manage.py startapp tasks 3、进入models.py定义数学模型 第2步得到的只是应用的必要空文件,要开始增加各文件实际…

PostgreSQL的学习心得和知识总结(一百四十八)|查看 PostgreSQL 17 中的新内置排序规则提供程序

目录结构 注:提前言明 本文借鉴了以下博主、书籍或网站的内容,其列表如下: 1、参考书籍:《PostgreSQL数据库内核分析》 2、参考书籍:《数据库事务处理的艺术:事务管理与并发控制》 3、PostgreSQL数据库仓库…

MongoDB Atlas Vector Search再度荣获最受欢迎的向量数据库称号

最新发布的《2024 年 Retool AI 现状报告》显示,MongoDB Atlas Vector Search 再次荣获最受欢迎的向量数据库称号,这已是它连续第二年获此殊荣。 Atlas Vector Search 在净推荐值 (NPS)方面斩获最高分,这一指标精准反映…

【python】pandas报错:UnicodeDecodeError详细分析,解决方案以及如何避免

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,…

一文带你看懂SAP-HANA的基本架构与原理

注:本篇主要对SAP HANA做了总结与论述,如有错误欢迎读者提出并补充 创作不易,希望大家一键三连支持!!!♥♥♥ 创作不易,希望大家一键三连支持!!!♥♥♥ 创作不易,希望大家一键三连支持!!!♥♥♥ 目录 一. 背景引入1.1 硬件与数据库系统1.2 行业现状 …

MongoDB自学笔记(一)

一、MongoDB简介 MongoDB是一款基于C开发的文档型数据库。与传统的关系型数据库有所不同,MongoDB面向的是文档,所谓的文档是一种名为BSON (Binary JSON:二进制JSON格式)是非关系数据库当中功能最丰富,最像…

萝卜快跑爆火的背后,美格智能如何助力无人车商业化?

近期,“订单量超过600万单”等夺人眼球的信息,让无人驾驶出租车“萝卜快跑”从江城武汉爆火出圈,在2024年的炎炎夏日为这座大火炉再添了一把火。热度背后,不少地方主管部门,近期也纷纷针对无人驾驶出租车、无人驾驶运输…

【C++】多态-最全解析(多态是什么?如何使用多态?多态的底层原理是什么?)

目录 一、前言 二、多态是什么? 三、多态的定义及实现 🔥 多态的构成条件🔥 🔥 虚函数的重写🔥 🔥虚函数重写的两个例外 🔥 🍍 协变返回类型 🥝 析构函数的重写…

OpenMesh入门,安装,运行示例Hello World

安装 环境 win10&#xff0c;qt5 源码下载编译 进入OpenMesh官网OpenMesh官网 https://www.graphics.rwth-aachen.de/software/openmesh/download/ 使用cmake gui 注意&#xff1a;先安装qt5 使用 CMake-Gui 构建 vs 2019 项目 注意 where is the source code 是<project…

Zotero推荐插件

绝大多数插件下载网址&#xff1a;Zotero 插件商店 适配&#xff1a;Zotero6 1. Zotero-style&#xff1a;标签分栏与阅读进度可视化 右键任意一个列的名字&#xff0c;会弹出一个右键菜单&#xff0c;可以勾选/取消勾选一个列&#xff0c;并且在最后有两个操作按钮是【列设置…