一、该文档仅为了总结经验,方便下次部署时跳过踩过的坑。其中MongoDB的复制原理、特点等参照的菜鸟教程,附地址:https://www.runoob.com/mongodb/mongodb-replication.html

二、背景:4台服务器,dn11,dn22,dn33,dn44

  1)dn11:主服务器;

  2)dn22,dn33:从服务器,用来备份;

  3)dn44:仲裁节点,用来当主服务挂掉,从服务器是偶数个时投票产生一个新的主服务器。

三、副本集搭建过程(直接在root下操作的):

  1、停掉正在运行的mongodb服务(在每一台上执行):

    1)已添加服务的停止方式:   

    systemctl stop mongodb.service;

    2)命令停止方式:

    mongod --shutdown --config /etc/mongodb/mongodb.conf

  2、修改配置文件(在每一台上执行):vim /etc/mongodb/mongodb.conf,修改后如下:

dbpath=/usr/local/mongodb/data
logpath=/usr/local/mongodb/logs/mongo.log
logappend=true
journal=true
quiet=true
port=27017
fork=true #后台运行
bind_ip=0.0.0.0 #允许任何IP进行连接
auth=true #是否授权连接
keyFile=/usr/local/mongodb/db/keyfile #keyFile
oplogSize=512 #oplog大小
replSet=wetest #集群名称

  重要提示:使用主从(这里不做介绍)或副本集时,如果需要开启安全认证方式登录,那么必须配置keyFile属性,并且每台服务器的keyFile必须相同

  3、生成keyfile(主服务器上执行),然后将keyfile拷贝到上面配置文件所在路径:

  1)生成90个字节大小的keyfile命令:具体设置多大看你喜欢了

  openssl rand -base64 90 > /usr/local/mongodb/db/keyfile;

  2)更改keyfile权限:

  chmod 600 keyfile

  3)将keyfile拷贝到从服务器:  

  scp  /usr/local/mongodb/db/keyfile root@dn22: /usr/local/mongodb/db/keyfile;

  scp  /usr/local/mongodb/db/keyfile root@dn33: /usr/local/mongodb/db/keyfile;

  scp  /usr/local/mongodb/db/keyfile root@dn44: /usr/local/mongodb/db/keyfile;

  4、启动mongodb服务(在每一台上执行):

    1)已添加服务的启动方式:   

    systemctl start mongodb.service;

    2)命令启动方式:

    mongod -f /etc/mongodb/mongodb.conf

 四、副本集操作过程(主服务器上执行):

  1、执行mongo命令;

  2、副本集初始化:

    1)直接初始化:

    > rs.initiate();

    2)先配置,再初始化,该方式不需要再添加从节点

    > rsConfig = { _id:"fleet", members:[{ _id:0, host:"dn22:27017" }, { _id:1, host:"dn33:27017" }] };
    > rs.initiate(rsConfig);

  初始化几秒过后> 变为wetest:PRIMARY> ,由于是总结性文档,我的截图并不连贯,变化过程如下面两图:

  

   

  3、添加从节点:

  wetest:PRIMARY> rs.add("dn22:27017");
  wetest:PRIMARY> rs.add("dn33:27017");

  

  添加完成后从服务器上> 变为wetest:SECONDARY>

  

  4、添加仲裁节点:  

  wetest:PRIMARY> rs.addArb("dn44:27017");

  添加完成后仲裁服务器上> 变为wetest:ARBITER>

  

  5、设置优先级:如果副本集只有一主一从,该操作可以避免重启服务后主从关系调换(血的教训)

    1)先将配置文件保存;

wetest:PRIMARY> cfg=rs.conf();
{
"_id" : "wetest",
"version" : 7,
"protocolVersion" : NumberLong(1),
"writeConcernMajorityJournalDefault" : true,
"members" : [
{
"_id" : 0,
"host" : "dn11:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 1,
"tags" : { },
"slaveDelay" : NumberLong(0),
"votes" : 1
},
{
"_id" : 1,
"host" : "dn22:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 1,
"tags" : { },
"slaveDelay" : NumberLong(0),
"votes" : 1
},
{
"_id" : 2,
"host" : "dn33:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 1,
"tags" : { },
"slaveDelay" : NumberLong(0),
"votes" : 1
},
{
"_id" : 3,
"host" : "dn44:27017",
"arbiterOnly" : true,
"buildIndexes" : true,
"hidden" : false,
"priority" : 0,
"tags" : { },
"slaveDelay" : NumberLong(0),
"votes" : 1
}
],
"settings" : {
"chainingAllowed" : true,
"heartbeatIntervalMillis" : 2000,
"heartbeatTimeoutSecs" : 10,
"electionTimeoutMillis" : 10000,
"catchUpTimeoutMillis" : -1,
"catchUpTakeoverDelayMillis" : 30000,
"getLastErrorModes" : { },
"getLastErrorDefaults" : {
"w" : 1,
"wtimeout" : 0
},
"replicaSetId" : ObjectId("5ee9e542473bf3ef79612476")
}
}

    2)设置优先级:

    wetest:PRIMARY> cfg.members[0].priority = 2;
    wetest:PRIMARY> cfg.members[0].priority = 1;
    wetest:PRIMARY> cfg.members[0].priority = 1;
    wetest:PRIMARY> cfg.members[0].priority = 0;

    3)重新加载配置项:

    wetest:PRIMARY> rs.reconfig(cfg);

    4)查看配置是否生效:

wetest:PRIMARY> cfg=rs.conf();
{
"_id" : "wetest",
"version" : 7,
"protocolVersion" : NumberLong(1),
"writeConcernMajorityJournalDefault" : true,
"members" : [
{
"_id" : 0,
"host" : "dn11:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 2,
"tags" : { },
"slaveDelay" : NumberLong(0),
"votes" : 1
},
{
"_id" : 1,
"host" : "dn22:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 1,
"tags" : { },
"slaveDelay" : NumberLong(0),
"votes" : 1
},
{
"_id" : 2,
"host" : "dn33:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 1,
"tags" : { },
"slaveDelay" : NumberLong(0),
"votes" : 1
},
{
"_id" : 3,
"host" : "dn44:27017",
"arbiterOnly" : true,
"buildIndexes" : true,
"hidden" : false,
"priority" : 0,
"tags" : { },
"slaveDelay" : NumberLong(0),
"votes" : 1
}
],
"settings" : {
"chainingAllowed" : true,
"heartbeatIntervalMillis" : 2000,
"heartbeatTimeoutSecs" : 10,
"electionTimeoutMillis" : 10000,
"catchUpTimeoutMillis" : -1,
"catchUpTakeoverDelayMillis" : 30000,
"getLastErrorModes" : { },
"getLastErrorDefaults" : {
"w" : 1,
"wtimeout" : 0
},
"replicaSetId" : ObjectId("5ee9e542473bf3ef79612476")
}
}

    可以看到主服务器的优先级变为了2。

    5)接下来就是执行一些创建用户、数据库、表等操作,详细可以看菜鸟教程,有需要也可以在评论区留言。

    6)在从服务器和仲裁服务器需要执行的操作:设置slave为true    

    wetest:ARBITER> rs.slaveOk();

  

mongodb副本集群使用总结的更多相关文章

  1. mongodb副本集群搭建

    一.环境介绍 1.机器信息 10.40.6.68 10.40.6.108 10.40.6.110 软件环境为centos 6.x 2.mongodb 下载链接地址 https://www.mongod ...

  2. MongoDB副本集学习(一):概述和环境搭建

    MongoDB副本集概述 以下图片摘自MongoDB官方文档:http://docs.mongodb.org/manual/core/replication-introduction/ Primary ...

  3. Mongodb副本集+分片集群环境部署记录

    前面详细介绍了mongodb的副本集和分片的原理,这里就不赘述了.下面记录Mongodb副本集+分片集群环境部署过程: MongoDB Sharding Cluster,需要三种角色: Shard S ...

  4. mongodb 搭建集群(分片+副本集)

    mongodb  搭建集群(分片+副本集) 一.搭建结构图: 二.搭建步骤:

  5. Mongodb副本集+分片集群环境部署

    前面详细介绍了mongodb的副本集和分片的原理,这里就不赘述了.下面记录Mongodb副本集+分片集群环境部署过程: MongoDB Sharding Cluster,需要三种角色: Shard S ...

  6. MongoDB和Java(6):Spring Data整合MongoDB副本集、分片集群

    最近花了一些时间学习了下MongoDB数据库,感觉还是比较全面系统的,涉及了软件安装.客户端操作.安全认证.副本集和分布式集群搭建,以及使用Spring Data连接MongoDB进行数据操作,收获很 ...

  7. elasticsearch与mongodb分布式集群环境下数据同步

    1.ElasticSearch是什么 ElasticSearch 是一个基于Lucene构建的开源.分布式,RESTful搜索引擎.它的服务是为具有数据库和Web前端的应用程序提供附加的组件(即可搜索 ...

  8. MongoDB副本集学习(三):性能和优化相关

    Read Preferences/读写分离 有时候为了考虑应用程序的性能或响应性,为了提高读取操作的吞吐率,一个常见的措施就是进行读写分离,MongoDB副本集对读写分离的支持是通过Read Pref ...

  9. MongoDB 副本集的原理、搭建、应用

    概念: 在了解了这篇文章之后,可以进行该篇文章的说明和测试.MongoDB 副本集(Replica Set)是有自动故障恢复功能的主从集群,有一个Primary节点和一个或多个Secondary节点组 ...

  10. MongoDB副本集学习(二):基本测试与应用

    简单副本集测试 这一节主要对上一节搭建的副本集做一些简单的测试. 我们首先进入primary节点(37017),并向test.test集合里插入10W条数据: . rs0:PRIMARY> ;i ...

随机推荐

  1. 再探 游戏 《 2048 》 —— AI方法—— 缘起、缘灭(1) —— Firefox浏览器下自动运行游戏篇

    四年前曾经写过一过博客: 对 游戏 < 2048 > 的一些思考 虽然过去几年了,但是这个游戏一直没有搞懂该怎么使用AI算法来进行求解,这里再次对这个问题进行一些探索. ========= ...

  2. 宝塔环境安装redis

    参考: http://www.bt.cn/Help/Find?id=92 步骤: 1. 在安装宝塔时 PHP 版本选 7.0: 2. 安装 redis:wget http://125.88.182.1 ...

  3. 随时随地与 LLMs 聊天的开源项目「GitHub 热点速览」

    众所周知,本地运行 LLMs 需要下载模型(体积大),并且还比较吃硬件配置.近日 GitHub 推出了 GitHub Models 服务,让开发者可以在 GitHub 上免费测试 Llama.Phi ...

  4. blender-主要操作技巧

    E 或 G 或 S 之后 不在同一平面的 处理1切换正视图    alt + z 切换透视模式  s + z +0 变成同一平面

  5. 旧物利用 - 将机顶盒改造为一台Linux开发机!

    前言 机顶盒型号:移动魔百盒CM201-2(CH),芯片组: hi3798mv300(hi3798mv3dmm),其他型号类似 理论上适用于以下SOC:Hi3798Mv100 / Hi3798Cv20 ...

  6. MFC对话框程序:实现程序启动画面

    MFC对话框程序:实现程序启动画面 对于比较大的程序,在启动的时候都会显示一个画面,以告诉用户程序正在加载,或者显示一些关于软件的信息,如Visual C++,Word, PhotoShop等.那么对 ...

  7. RabbitMq消息可靠性之确认模式 通俗易懂 超详细 【内含案例】

    RabbitMq保证消息可靠性之确认模式 介绍 消息的确认,是指生产者投递消息后,如果 Broker 收到消息,则会给我们生产者一个应答.生产者进行接收应答,用来确定这条消息是否正常的发送到 Brok ...

  8. C#应用 - 事件总线

    目录 前言 1,简介 2,设计 2.1 设计思路 2.2 设计实现 2.2.1 IEventData 2.2.2 EventBus 2.2.3 用起来 3,问题 3.1 起缘 3.2 改造 3.3 用 ...

  9. 解密华为问界M7 Pro:智能出行的全新里程碑与技术亮点

    解读华为问界M7 Pro的智能里程碑 引言 2024年8月,智能出行领域迎来了一个激动人心的时刻--问界M7 Pro的重磅发布.这款智能SUV,不仅是华为在汽车领域的又一次大胆尝试,更是鸿蒙智行系统的 ...

  10. elastersearch7.6.1搭建及基本操作详解

    搭建 修改系统参数 vim /etc/security/limits.conf * soft nofile 655350 * hard nofile 655350 * soft nofile 6553 ...