MongoDB3.0.6搭建主从复制集

什么是复制集?

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