什么是复制集?
复制集(Replica Sets)是额外的数据副本,是跨多个服务器同步数据的过程,复制集提供了冗余并增加了数据可用性,通过复制集可以对硬件故障和中断的服务进行恢复。
或者
MongoDB复制是将数据同步在多个服务器的过程。复制提供了数据的冗余备份,并在多个服务器上存储数据副本,提高了数据的可用性, 并可以保证数据的安全性。复制还允许您从硬件故障和服务中断中恢复数据。
- mongodb(M)表示主节点,mongodb(S)表示备节点,mongodb(A)表示仲裁节点。主备节点存储数据(M,S),仲裁节点不存储数据。客户端同时连接主节点与备节点,不连接仲裁节点。
- 默认设置下,主节点提供所有增删查改服务,备节点不提供任何服务。但是可以通过设置使备节点提供查询服务,这样就可以减少主节点的压力,当客户端进行数据查询时,请求自动转到备节点上。这个设置叫做Read Preference Modes,同时Java客户端提供了简单的配置方式,可以不必直接对数据库进行操作。
- 仲裁节点是一种特殊的节点,它本身并不存储数据,主要的作用是决定哪一个备节点在主节点挂掉之后提升为主节点,所以客户端不需要连接此节点。这里虽然只有一个备节点,但是仍然需要一个仲裁节点来提升备节点级别。
搭建复制集
准备
mongo版本3.0.6、三台centos7三个节点固定ip
192.168.50.120、192.168.50.121、192.168.50.122(作为仲裁节点)每个节点分别下载解压mongodb-linux-x86_64-3.0.6
curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0.6.tgz
- 每个节点分别解压tgz
tar -zxvf mongodb-linux-x86_64-3.0.6.tgz
- 每个节点分别移动到指定目录
mv mongodb-linux-x86_64-3.0.6/usr/local/mongodb
- 每个节点分别设置环境变量
export PATH=mongodb-linux-x86_64-3.0.6/usr/local/mongodb/bin:$PATH
- 每个节点分别创建mongo数据库文件位置
mkdir /data/db
- 每个节点分别创建mongo日志目录
mkdir /data/mongo/
- 每个节点分别创建mongodb.conf,文件位置 /etc/mongodb.conf
#日志文件位置
logpath=/data/mongo/mongod.log
# 以追加方式写入日志
logappend=true
# 是否以守护进程方式运行
#fork = true
# 默认27017
#port = 27017
# 数据库文件位置
#dbpath=/data/mongo/db
# 启用定期记录CPU利用率和 I/O 等待
#cpu = true
# 是否以安全认证方式运行,默认是不认证的非安全方式
#noauth = true
#auth = true
# 详细记录输出
#verbose = true
# Inspect all client data for validity on receipt (useful for
# developing drivers)用于开发驱动程序时验证客户端请求
#objcheck = true
# Enable db quota management
# 启用数据库配额管理
#quota = true
# 设置oplog记录等级
# Set oplogging level where n is
# 0=off (default)
# 1=W
# 2=R
# 3=both
# 7=W+some reads
#diaglog=0
# Diagnostic/debugging option 动态调试项
#nocursors = true
# Ignore query hints 忽略查询提示
#nohints = true
# 禁用http界面,默认为localhost:28017
#nohttpinterface = true
# 关闭服务器端脚本,这将极大的限制功能
# Turns off server-side scripting. This will result in greatly limited
# functionality
#noscripting = true
# 关闭扫描表,任何查询将会是扫描失败
# Turns off table scans. Any query that would do a table scan fails.
#notablescan = true
# 关闭数据文件预分配
# Disable data file preallocation.
#noprealloc = true
# 为新数据库指定.ns文件的大小,单位:MB
# Specify .ns file size for new databases.
# nssize =
#复制集名称
replSet=repl1
# maximum size in megabytes for replication operation log
#oplogSize=1024
# path to a key file storing authentication info for connections
# between replica set members
#指定存储身份验证信息的密钥文件的路径
keyFile=/data/mongo/akey
- 单个节点创建keyfile,之后拷贝到其他从节点
openssl rand -base64 756 > /data/mongo/akey
chmod 400 /data/mongo/akey
chmod 600 /data/mongo/akey
- 每个节点分别启动服务端
./mongod -config /etc/mongodb.conf
- 客户端连接mongo
./mongo
- 单个节点初始化一个复制集作为主节点
rs.initiate({_id:'repl1',members:[{_id:1,host:'192.168.50.120:27017'}]})
- 每个节点分别配置管理员账号,角色为内置角色root
use admin
db.createUser({user:"moda",pwd:"moda",roles:[{role:"root",db:"admin"}]})
- 使用验证登录
use admin
db.auth("moda","moda")
db.shutdownServer();
- 在主节点上添加从节点
use admin
db.auth("moda","moda")
rs.add('192.168.50.121:27017')
- 在主节点上添加仲裁节点
use admin
db.auth("moda","moda")
rs.addArb('192.168.50.122:27017')
- 验证看一下节点状态
rs.status();
rs.conf();
- 主节点添加一条数据
use moda
db.moda.insert({"name":"moda"})
db.moda.find().pretty()
- 登录从节点验证数据
use admin;
db.auth("moda","moda");
rs.slaveOk();
use moda;
db.moda.find().pretty();
- 常用命令
- rs.initiate():复制集初始化, 例如:
rs.initiate({_id:'repl1',members:[{_id:1,host:'192.168.50.120:27017'}]})
- rs.reconfig():重新加载配置文件,当只剩下一个secondary节点时,复制集变得不可用,则可以指定force属性强制将节点变成primary,然后再添加secondary节点。例如:
rs.reconfig({_id:'repl1',members:[{_id:1,host:'192.168.50.121:27017'}]},{force:true});
- 查看复制集状态
rs.status()
- 查看复制情况
db.printSlaveReplicationInfo()
- 查看复制集配置
rs.conf()/rs.config():
- 在当前连接让secondary可以提供读操作
rs.slaveOk()
- rs.add():增加复制集节点,例如:
rs.add('192.168.50.121:27017')
- 指定hidden属性添加备份节点
rs.add({"_id":3,"host":"192.168.50.121:27017","priority":0,"hidden":true})
- 指定slaveDelay属性添加延迟节点
rs.add({"_id":3,"host":"192.168.50.121:27017","priority":0,"slaveDelay":60})
priority:是优先级,默认为1,如果想手动指定某个节点为primary节点,则把对应节点的priority属性设置为所有节点中最大的一个即可
- rs.remove():删除复制集节点,例如:
rs.remove('192.168.50.121:27017')
- rs.addArb():添加仲裁节点。仲裁节点,只参与投票,不接收数据。例如:
rs.addArb('192.168.50.122:27017');
rs.add({"_id":3,"host":"192.168.50.122:27017","arbiterOnly":true})
- 安装出现的问题
- -
- -
- -
- 需启动IP:122mongo服务
- 本文参考文档
- 搭建mongo
- https://blog.csdn.net/benben_2015/article/details/83065478
- https://zhidao.baidu.com/question/714586635180959525.html
- 搭建复制集
- https://www.cnblogs.com/nicolegxt/p/6841442.html?utm_source=itdadao&utm_medium=referral
- https://www.cnblogs.com/shengdimaya/p/6598450.html