MongoDB 副本集配置

一.什么是MongoDB副本集?

副本集是一组mongod维护相同数据集的实例,它提供了数据的冗余备份,并在多个服务器上存储数据副本,提高了数据的可用性, 并可以保证数据的安全性;还允许您从硬件故障和服务中断中恢复数据;实现自动故障转移,还可以采用分布式方式读取数据。

二.MongoDB副本集的原理?

mongodb的复制至少需要两个节点。其中一个是主节点,负责处理客户端请求,其余的都是从节点,负责复制主节点上的数据。mongodb各个节点常见的搭配方式为:一主一从、一主多从。

主节点记录在其上的所有操作oplog,从节点定期轮询主节点获取这些操作,然后对自己的数据副本执行这些操作,从而保证从节点的数据与主节点一致。
通过在不同数据库服务器上提供多个数据副本,复制可提供一定级别的容错功能,以防止丢失单个数据库服务器。

三.MongoDB副本集同步?

  1. 克隆除本地数据库之外的所有数据库。要克隆mongod扫描每个源数据库中的每个集合,并将所有数据插入到这些集合的自己的副本中。版本3.4中已更改:初始同步会在为每个集合复制文档时构建所有集合索引。在早期版本的MongoDB中,仅_id在此阶段构建索引。初始同步在数据复制期间提取新添加的oplog记录。确保目标成员在local 数据库中有足够的磁盘空间,以便在此数据复制阶段的持续时间内临时存储这些oplog记录。

  2. 将所有更改应用于数据集。使用源中的oplog,mongod更新其数据集以反映副本集的当前状态。

    初始同步完成后,成员从转换 STARTUP2SECONDARY

四.部署MongoDB副本集的注意事项

  • 如果可能,请使用逻辑DNS主机名而不是IP地址,尤其是在配置副本集成员或分片集群成员时。逻辑DNS主机名的使用避免了由于IP地址更改而导致的配置更改。
  • IP绑定 3.6版本之后才默认绑定地址为localhost,所以最好还是配置--bind-ip参数,如若绑定的非本地计算机,请确保已保护您的群集免受未经授权的访问,最好考虑启用身份验证强化网络基础架构
  • 确保网络流量可以在集合的所有成员和网络中的所有客户端之间安全地传递
    1.建立虚拟专用网络。确保您的网络拓扑通过局域网路由单个站点内的成员之间的所有流量。
    2.配置访问控制以防止从未知客户端到副本集的连接。
    3.配置网络和防火墙规则,以便仅在默认的MongoDB端口上允许传入和传出的数据包,并且仅在部署中允
  • 最好部署具有已启用访问控制的副本集
  • 备份数据库在备份时会出现一定的延迟
  • 启动MongoDB 需以副本集模式启动
  • 备份数据库必须设置votes 值为1才拥有选举成为Primary服务器的可能

五.MongoDB副本集的需要哪些资源配置?

一台安装好MongoDB 的服务器 192.168.1.1
或者
三台安装好MongoDB 的服务器 192.168.1.1 192.168.1.2 192.168.1.3
网络处于可使用状态

六.部署MongoDB副本集

1. 设置配置文件
通过 --replSet --bind_ip 命令行选项指定副本集名称和ip绑定
语法:mongod --replSet "rs0" -- bind_ip localhost,<hostname ( s )| ip address ( es ) >
或者使用配置文件指定 replica set name 和 ip addresses

systemLog
    path: /var/log/mongodb/mongodb.log

storage
    dbPath: /var/lib/mongo-res1
    journal: 
        enabled: true
replication:
   replSetName : rs0
net :
   bindIp : localhost,<hostname(s)| ip address(es)>

配置参数含义:
replSet:设置Replica Set的name,在各个配置文件中,其值必须相同。
dbpath:MongoDB用于存储数据的目录,默认值是C:\data\db
bind_ip 指定ip
path:用于记录mongod的日志数据
port:指定MongoDB监听的端口,默认值是27017

然后要使用配置文件启动MongoDB实例 ,使用 --config 选项指定配置文件的路径。

mongod --config <path-to-config>

三个实例启动完毕后,查看 ps -ef|grep mongo


我这里是一台服务配置的三个实例

2.使用 mongoDB shell 连接到其中一个 mongod 实例
mongo --host 192.168.1.1 --port 27017

3.启动副本集
使用 rs.initiate() 来指定副本集的所有成员

rs.initiate({
   _id : "rs0",
   members :[
      {  _id : 0 , host: "192.168.1.1:27017"},
      {  _id : 1 , host: "192.168.1.1:27019"},
      {  _id : 2 , host: "192.168.1.1:27019"} 
   ] 
})
image.png

4.查看副本集配置

rs.conf()

5.查看副本集主副本信息

rs.status()

七.应用MongoDB副本集

尝试关闭主节点
db.shutdownServer();
或者使用kill 端口的方式

image.png

然后再查看剩下的两个副节点是否有一个成为新的节点
stateStr : "PRIMARY" 就是主节点

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容