第35章:MongoDB-集群--Master Slave(主从复制)

Posted new个对象当老婆

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第35章:MongoDB-集群--Master Slave(主从复制)相关的知识,希望对你有一定的参考价值。

①主从复制[不推荐使用了]

最基本的设置方式就是建立一个主节点和一个或多个从节点,每个从节点要知道主节点的地址。采用双机备份后主节点挂掉了后从节点可以接替主机继续服务,所以这种模式比单节点的高可用性要好很多。

②注意点

1)在数据库集群中要明确的知道谁是主服务器,主服务器只有一台.

2)从服务器要知道自己的数据源也就是对应的主服务是谁.

3)--master用来确定主服务器,--slave 和 --source 来控制从服务器

③主从复制的原理

在主从结构中,主节点的操作记录成为oplog(operation log)。oplog存储在一个系统数据库local的集合oplog.$main中,这个集合的每个文档都代表主节点上执行的一个操作。

从服务器会定期从主服务器中获取oplog记录,然后在本机上执行!对于存储oplog的集合,MongoDB采用的是固定集合,也就是说随着操作过多,新的操作会覆盖旧的操作!

主从复制搭建--单机

 

1:先创建几个存放数据的文件夹,比如在前面的dbs下面创建db1,db2

同理在前面的logs下面创建logs1,logs2

2:在启动MongoDB服务器的时候,使用--replSet副本集名称选项,如

./mongod --dbpath ../dbs/db1 --logpath ../logs/logs1 --port 20001 --fork --master

3:然后再启动两个,端口为20002,当然要修改相应的数据文件路径和日志路径,副本集名称

./mongod --dbpath ../dbs/db2 --logpath ../logs/logs2 --port 20002 --fork --slave  --source localhost:20001

4:

./mongo localhost:20001

./mongo localhost:20002

5:添加和删除源

除了可以在启动从节点的时候,制定source外,也可以在从节点的local数据库的sources集合里面添加主节点的信息,如:

db.sources.insert({“host”:”ip:port”});

不用了,就remove就好了

 

主从复制搭建--多机

 

1)机器环境

 

182.48.115.238    master-node

182.48.115.236    slave-node

两台机器都关闭防火墙和selinux

2)主从配置

.............master-node节点配置.............

[[email protected] ~]# vim /usr/local/mongodb/mongodb.conf

port=27017

bind_ip = 182.48.115.238

dbpath=/usr/local/mongodb/data

logpath=/usr/local/mongodb/log/mongo.log

logappend=true

journal = true

fork = true

master = true        //确定自己是主服务器

 

 

[[email protected] ~]# bin/mongod -f mongodb.conf

./mongo IP:PORT

 

.............slave-node节点配置.............

[[email protected] ~]# vim /usr/local/mongodb/mongodb.conf

port=27017

dbpath=/usr/local/mongodb/data

logpath=/usr/local/mongodb/log/mongo.log

logappend=true

journal = true

fork = true

bind_ip = 182.48.115.236            

source = 182.48.115.238:27017

slave = true

 

 

 

[[email protected] ~]# bin/mongod -f mongodb.conf

./mongo IP:PORT

 

 

 

 

 

 

 

 

 

 

 

 

 

 

?
 

 

?
 

 

?
 

 

?
 

 

?
 

 

?
 

 

?
 

 

?
 

 

?
 

 

?
 

 

以上是关于第35章:MongoDB-集群--Master Slave(主从复制)的主要内容,如果未能解决你的问题,请参考以下文章

Practical Node.js (2018版) 第5章:数据库 使用MongoDB和Mongskin。

[云原生专题-28]:K8S - Kubernetes(K8S)Master集群构建与安装过程详细解读 - Dashboard的安装与访问

MongoDB集群搭建

MongoDB搭建ReplSet复制集群

MongoDB Sharding Cluster分片集群

MongoDB学习