复制集(Replica Sets)是额外的数据副本,是跨多个服务器同步数据的过程,复制集提供了冗余备份并提升了数据的可用性,经过复制集能够对硬件故障和中断的服务进行恢复。mongodb
- mongodb的复制集至少须要两个节点。其中一个是主节点(Primary),负责处理客户端请求,其他的都是从节点(Secondary),负责复制主节点上的数据。
- mongodb各个节点常见的搭配方式为:一主一从、一主多从。主节点记录其上的全部操做到 oplog 中,从节点按期轮询主节点获取这些操做,而后对本身的数据副本执行这些操做,从而保证从节点的数据与主节点一致。
- 客户端在主节点写入数据,在从节点读取数据,主节点与从节点进行数据交互保障数据的一致性。若是其中一个节点出现故障,其余节点立刻会将业务接过来而无需停机操做。
复制集的特色:vim
- N个节点的群集
- 任何节点均可做为主节点
- 全部写入操做都在主节点上
- 自动故障转移
- 自动恢复
- 让数据更安全
- 高数据可用性(24x7)
- 灾难恢复
- 无停机维护(如备份、索引重建、故障转移)
- 读缩放(额外的副本读取)
- 副本集对应用程序是透明的
咱们能够在一台服务器上建立多实例,来作复制集
MongoDB安装及建立多实例详解在博文CentOS 7安装MongoDB(最新版4.0)安全
# 建立实例的数据目录 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
# 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
须要注意其余三个实例的配置文件中的数据文件存放位置及日志文件和端口要改
bash
[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
mongo #(默认端口:27017) > rs.status()
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"}]}
4.3 启动复制集功能,初始化配置时保证从节点没有数据,保持主从节点数据同步app
> rs.initiate(cfg)
testrc:PRIMARY> rs.add("192.168.125.119:27020")
testrc:PRIMARY> rs.remove("192.168.125.119:27020")