我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MongoDB复制集角色类型详解

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MongoDB复制集角色类型详解


                      MongoDB复制集角色类型

MongoDB复制集角色类型

1、标准节点: 参与primary选举,当自身宕机或停止服务会自动让出primary

2、被动节点: 只能成为second 不参与选举,被设置为被动节点则不能参与选举

3、仲裁节点:负责投票选举,不存放数据,确保标准节点投票数不会相同


用实验来验证一下标准节点互相抢占和被动节点不会抢占以及仲裁节点不存放数据。

利用MongoDB多实例进行实验,yum安装MongoDB以及开启多实例请参考以下

我的另一篇博客:https://blog.51cto.com/13760226/2174032


实验角色

●标准节点1:192.168.60.135:27017

●标准节点2:192.168.60.135:27018

●被动节点 :192.168.60.135:27019

●仲裁节点 :192.168.60.135:27020


一、修改配置文件

vim  /etc/mongod.conf

systemLog:        #日志模块下修改日志文件路径

  destination: file

  logAppend: true

  path: /usr/local/mongodb/mongod1.log

(剩下实例也要修改,例:mongod2.log,mongod3.log,mongod4.log)


storage:      #存储模块下修改数据配置文件

  dbPath: /usr/local/mongo1

(同上,例:mongo2,mongo3,mongo4)


net:

  port: 27017         每个实例端口号不能相同(例:27018,27019,27020)

  bindIp: 0.0.0.0     监听任意地址


直接添加如下两行,开启复制集

replication: 

  replSetName: repl



二、复制配置文件,创建各自数据存放目录

cp /etc/mongod.conf /etc/mongod2.conf

cp /etc/mongod.conf /etc/mongod3.conf

cp /etc/mongod.conf /etc/mongod4.conf



mkdir /usr/local/mongo{1,2,3,4}    #一次创建4个数据存放目录(与配置文件的对应)

mkdir /usr/local/mongodb  #创建日志存放目录

touch mongod{1,2,3,4}.log   #创建实例对应日志文件

(注意:不要忘记修改复制的配置文件,端口号不能相同)


三、开启多实例,设置标准,被动,仲裁节点

[root@localhost ~]#mongod -f /etc/mongod.conf

[root@localhost ~]#mongod -f /etc/mongod2.conf

[root@localhost ~]#mongod -f /etc/mongod3.conf

[root@localhost ~]#mongod -f /etc/mongod4.conf


[root@localhost mongodb]# netstat -ntap | grep mongod

tcp        0      0 0.0.0.0:27019           0.0.0.0:*               LISTEN      2280/mongod         

tcp        0      0 0.0.0.0:27020           0.0.0.0:*               LISTEN      2308/mongod         

tcp        0      0 0.0.0.0:27017           0.0.0.0:*               LISTEN      2224/mongod         

tcp        0      0 0.0.0.0:27018           0.0.0.0:*               LISTEN      2252/mongod  


1)进入其中一个Mongodb进行设置,本文以27017为例

mongo进入数据库,设置如下

>cfg={"_id":"repl","members":

[{"_id":0,"host":"192.168.60.135:27017","priority":100},

{"_id":1,"host":"192.168.60.135:27018","priority":100},

{"_id":2,"host":"192.168.60.135:27019","priority":0},

{"_id":3,"host":"192.168.60.135:27020","arbiterOnly":true}]}


cfg只是一个名字,类似于变量。将27017和27018优先级设置为100,

27019的优先级为0,没有资格参与选举,27020设置为arbite,为仲裁复制集。


> rs.initiate(cfg)               #进行初始化

{                              #提示如下信息

            "ok" : 1,

            "operationTime" : Timestamp(1536851525, 1),

            "$clusterTime" : {

                    "clusterTime" : Timestamp(1536851525, 1),

                    "signature" : {

                            "hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),

                             "keyId" : NumberLong(0)

                        }

                    }

      }


2)查看状态

repl:PRIMARY> rs.status()


MongoDB复制集角色类型详解

MongoDB复制集角色类型详解

MongoDB复制集角色类型详解


27017被选为标准节点,27018有选举权但是已经有标准节点,所以变为被动节点,

27019被选为被动节点,27020被设置为仲裁节点。


四、验证

1)验证标准节点会互相抢占

repl:PRIMARY> rs.stepDown()    #主动放弃主复制权


MongoDB复制集角色类型详解

MongoDB复制集角色类型详解



2)验证被动节点不抢占

[root@localhost ~]# mongod -f /etc/mongod.conf --shutdown

killing process with pid: 2224

[root@localhost ~]# mongod -f /etc/mongod2.conf --shutdown

killing process with pid: 2252

关闭27017和27018的MongoDB

[root@localhost ~]# mongo -port 27019   #进入mongodb端口27019

  >rs.status()


MongoDB复制集角色类型详解

MongoDB复制集角色类型详解

MongoDB复制集角色类型详解


结论:当两台标准节点宕机时,被动节点也不会顶替成为标准节点,因为没有选举权。


3)验证仲裁服务器不存储数据


开启MongoDB27017端口

[root@localhost ~]# mongod -f /etc/mongod.conf

mongo    #登陆


use list;    #创建一个数据库

db.list.insert({"name":"zhangsan"})     创建list集合并插入信息    

repl:PRIMARY> db.list.find();             查询list

{ "_id" : ObjectId("5b9a8ae579c4aae2378a4fd6"), "name" : "zhangsan" }


然后我们切换到27020仲裁服务器

[root@localhost ~]# mongo -port 27020

rs.slaveOk()    #先输出该命令,不然无法查看


repl:ARBITER> show dbs;     #查看数据库

local  0.000GB           #只能看见一个数据库local


结论:仲裁服务器只负责投票选举,不参与数据存储


免责声明:

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

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

MongoDB复制集角色类型详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Golang拾遗之实现一个不可复制类型详解

在这篇文章中我们将实现一个无法被复制的类型,顺便加深对引用类型、值传递以及指针的理解。文中的示例代码讲解详细,感兴趣的可以了解一下
2023-02-20

编程热搜

目录