文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

部署MongoDB复制集(主从复制、读写分离、高可用)

2024-04-02 19:55

关注

MongoDB 复制集

复制集(Replica Sets)是额外的数据副本,是跨多个服务器同步数据的过程,复制集提供了冗余备份并提高了数据的可用性,通过复制集可以对硬件故障和中断的服务进行恢复。

MongoDB 复制集工作原理

  1. mongodb的复制集至少需要两个节点。其中一个是主节点(Primary),负责处理客户端请求,其余的都是从节点(Secondary),负责复制主节点上的数据。
  2. mongodb各个节点常见的搭配方式为:一主一从、一主多从。主节点记录其上的所有操作到 oplog 中,从节点定期轮询主节点获取这些操作,然后对自己的数据副本执行这些操作,从而保证从节点的数据与主节点一致。
  3. 客户端在主节点写入数据,在从节点读取数据,主节点与从节点进行数据交互保障数据的一致性。如果其中一个节点出现故障,其他节点马上会将业务接过来而无需停机操作。

MongoDB 复制集的特点及优势

MongoDB 复制集部署

我们可以在一台服务器上创建多实例,来做复制集
MongoDB安装及创建多实例详解在博文CentOS 7安装MongoDB(最新版4.0)

配置复制集

  1. 创建4个 MongoDB 实例
    # 创建实例的数据目录
    mkdir -p /data/mongodb/mongodb{1,2,3,4}
     
    # 创建实例的日志目录
    mkdir -p /data/logs
     
    # 创建实例的日志文件
    touch /data/logs/mongodb{1,2,3,4}.log
     
     # 赋予日志文件权限
     chmod 777 /data/logs/mongodb*.log
     
     #创建实例的配置文件存放位置
     mkdir -p /data/conf

     

  2. 创建配置文件,开启复制集功能
    这里博主偷了个小懒,将配置文件存放在之前创建的 /data/conf/ 目录下,后面创建的启动脚本为实验机的相对路径
    # vim /data/conf/mongodb1.conf  //简易配置为下,
        dbpath=/data/mongodb/mongodb1
        logpath=/data/logs/mongodb1.log
        port=27017
        replSet=testrc   #配置参数值为testrc
        logappend=true
        fork=true
        maxConns=5000  
        storageEngine=mmapv1

    需要注意其他三个实例的配置文件中的数据文件存放位置及日志文件和端口要改
     

  3. 编写脚本方便对4条实例进行控制(这里用的是相对路径,请根据实际修改)
    [root@CentOS7 conf]# cd /usr/local/mongodb/bin
    [root@CentOS7 bin]# vim mongodb
     
    #!/bin/bash
    INSTANCE=$1
    ACTION=$2
    case "$ACTION" in
    'start')
    /usr/local/mongodb/bin/mongod -f /data/conf/"$INSTANCE".conf;;
    'stop')
    /usr/local/mongodb/bin/mongod -f /data/conf/"$INSTANCE".conf --shutdown;;
    'restart')
    /usr/local/mongodb/bin/mongod -f /data/conf/"$INSTANCE".conf --shutdown
    /usr/local/mongodb/bin/mongod -f /data/conf/"$INSTANCE".conf;;
    esac
     
    [root@CentOS7 bin]# chmod +x mongodb
    [root@CentOS7 bin]# ./mongodb mongodb1 restart
    [root@CentOS7 bin]# ./mongodb mongodb2 restart
    [root@CentOS7 bin]# ./mongodb mongodb3 restart
    [root@CentOS7 bin]# ./mongodb mongodb4 restart
    [root@CentOS7 bin]# netstat -ntap | grep mongod

    部署MongoDB复制集(主从复制、读写分离、高可用)
     

  4. 配置三个节点的复制集
     
    4.1 查看复制集的状态信息
    mongo    #(默认端口:27017)
    > rs.status()

    部署MongoDB复制集(主从复制、读写分离、高可用)
     
    4.2 定义cfg初始化参数(这里添加三台,剩下的那台实验添加节点功能)

    > cfg={"_id":"testrc","members":[{"_id":0,"host":"192.168.125.119:27017"},{"_id":1,"host":"192.168.125.119:27018"},{"_id":2,"host":"192.168.125.119:27019"}]}

    部署MongoDB复制集(主从复制、读写分离、高可用)
     
    4.3 启动复制集功能,初始化配置时保证从节点没有数据,保持主从节点数据同步

    > rs.initiate(cfg)

     

  5. 添加节点
    testrc:PRIMARY>  rs.add("192.168.125.119:27020")

     

  6. 删除节点
    testrc:PRIMARY>  rs.remove("192.168.125.119:27020")
阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯