MongoDB极简教程 · Mongo · NoSQLmongoDB

MongoDB3.0.6搭建主从复制集

2020-01-29  本文已影响0人  tony_zhang

什么是复制集?

  • 复制集(Replica Sets)是额外的数据副本,是跨多个服务器同步数据的过程,复制集提供了冗余并增加了数据可用性,通过复制集可以对硬件故障和中断的服务进行恢复。
    或者
    MongoDB复制是将数据同步在多个服务器的过程。复制提供了数据的冗余备份,并在多个服务器上存储数据副本,提高了数据的可用性, 并可以保证数据的安全性。复制还允许您从硬件故障和服务中断中恢复数据。


  • mongodb(M)表示主节点,mongodb(S)表示备节点,mongodb(A)表示仲裁节点。主备节点存储数据(M,S),仲裁节点不存储数据。客户端同时连接主节点与备节点,不连接仲裁节点。
  • 默认设置下,主节点提供所有增删查改服务,备节点不提供任何服务。但是可以通过设置使备节点提供查询服务,这样就可以减少主节点的压力,当客户端进行数据查询时,请求自动转到备节点上。这个设置叫做Read Preference Modes,同时Java客户端提供了简单的配置方式,可以不必直接对数据库进行操作。
  • 仲裁节点是一种特殊的节点,它本身并不存储数据,主要的作用是决定哪一个备节点在主节点挂掉之后提升为主节点,所以客户端不需要连接此节点。这里虽然只有一个备节点,但是仍然需要一个仲裁节点来提升备节点级别。

搭建复制集

curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0.6.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
mkdir /data/db
mkdir /data/mongo/
#日志文件位置
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
openssl rand -base64 756 > /data/mongo/akey
chmod 400 /data/mongo/akey
chmod 600 /data/mongo/akey
./mongod -config /etc/mongodb.conf
./mongo
rs.initiate({_id:'repl1',members:[{_id:1,host:'192.168.50.120:27017'}]})
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();
  1. rs.initiate():复制集初始化, 例如:
rs.initiate({_id:'repl1',members:[{_id:1,host:'192.168.50.120:27017'}]}) 
  1. rs.reconfig():重新加载配置文件,当只剩下一个secondary节点时,复制集变得不可用,则可以指定force属性强制将节点变成primary,然后再添加secondary节点。例如:
rs.reconfig({_id:'repl1',members:[{_id:1,host:'192.168.50.121:27017'}]},{force:true});
  1. 查看复制集状态
rs.status()
  1. 查看复制情况
db.printSlaveReplicationInfo()
  1. 查看复制集配置
rs.conf()/rs.config():
  1. 在当前连接让secondary可以提供读操作
rs.slaveOk()
  1. rs.add():增加复制集节点,例如:
rs.add('192.168.50.121:27017') 
  1. 指定hidden属性添加备份节点
rs.add({"_id":3,"host":"192.168.50.121:27017","priority":0,"hidden":true})
  1. 指定slaveDelay属性添加延迟节点
rs.add({"_id":3,"host":"192.168.50.121:27017","priority":0,"slaveDelay":60})

priority:是优先级,默认为1,如果想手动指定某个节点为primary节点,则把对应节点的priority属性设置为所有节点中最大的一个即可

  1. rs.remove():删除复制集节点,例如:
rs.remove('192.168.50.121:27017')
  1. rs.addArb():添加仲裁节点。仲裁节点,只参与投票,不接收数据。例如:
rs.addArb('192.168.50.122:27017');
rs.add({"_id":3,"host":"192.168.50.122:27017","arbiterOnly":true})
  1. -
  2. -
  3. -
  4. 需启动IP:122mongo服务
  1. 搭建mongo
  1. 搭建复制集
上一篇下一篇

猜你喜欢

热点阅读