MongoDB的主从复制和副本集
mongoDB的两个特性主从复制和副本集,实现了数据的同步备份
一、主从复制
主从复制是一个简单的数据库同步备份的集群技术.例如主服务器宕机了,可以直接使用从服务器,主服务器恢复后在进行同步,保证了业务的连续性
注意点:
- 主服务器只有一台
- 从服务器需要知道自己的数据源,也就是对应的主服务器
- --master确定主服务器,--slave和--source来控制从服务器
1.举例:
1).主服务器的端口是60000
2).从服务器的端口是60001
如何配置主从复制?
主服务器的配置:
dbpath = D:\MongoDBMSCopy\Master 主数据库地址
port = 60000 主数据库端口号
bind_ip = 127.0.0.1 主数据库所在服务器
master = true 确定我是主服务器
从服务器的配置
dbpath = D:\MongoDBMSCopy\Slave 从数据库地址
port = 60001 从数据库端口号
bind_ip = 127.0.0.1 从数据库所在服务器
source = 127.0.0.1:60000 确定我数据库端口
slave = true 确定自己是从服务器
配置文件写好之后,就可以通过命令来启动主从服务器了,
如下:
启动主服务器
C:\Windows\system32>mongod --config D:\MongoDBMSCopy\Master\Master.conf
启动从服务器
C:\Windows\system32>mongod --config D:\MongoDBMSCopy\Slave\slave.conf
验证是否进行了复制
①打开cmd,连接主服务器,并建立一个Students数据库,插入一个文档名为Students
查看一下数据
> db.students.find()
{ "_id" : 1, "name" : "BigOrange", "age" : 25 }
②打开cmd连接从服务器
如上图所示,证明已经进行了复制
2.主从复制的其他设置项
--only 从节点→指定复制某个数据库,默认是复制全部数据库
--slavedelay 从节点→设置主数据库同步数据的延迟(单位是秒)
--fastsync 从节点→以主数据库的节点快照为节点启动从数据库
--autoresync 从节点→如果不同步则从新同步数据库
--oplogSize 主节点→设置oplog的大小(主节点操作记录存储到local的oplog中)
3.利用shell动态添加和删除从节点
在从数据库中的local数据库会多一个sources文档,它保存着主服务器的信息
如何进行动态添加从节点呢,和正常的添加数据的操作一样,直接通过insert插入remove删除
挂接主节点:
db.sources.insert({“host”:”127.0.0.1:60000”})
删除已经挂接的主节点:
db.sources.remove({“host”:”127.0.0.1:60000”})
二、副本集
第一张图表明A是活跃的B和C是用于备份的
第二张图当A出现了故障,这时候集群根据权重算法推选出B为活跃的数据库
第三张图当A恢复后他自动又会变为备份数据库
例:如何配置一个副本集服务器集群
1.假如有上面ABC三台服务器,如何进行配置呢,同样需要修改配置文件
对于A服务器:
dbpath = D:\MongoDBCopy\A\MongoDB_A.conf #A的配置
port=11111 #端口号
bind_ip=127.0.0.1 #IP地址
replSet = child/127.0.0.1:22222 #设定同伴,这里是B
对于B服务器:
dbpath = D:\MongoDBCopy\B\MongoDB_B.conf #A的配置
port=22222 #端口号
bind_ip=127.0.0.1 #IP地址
replSet = child/127.0.0.1:33333 #设定同伴,这里是C
对于C服务器:
dbpath = D:\MongoDBCopy\C\MongoDB_C.conf #A的配置
port=33333 #端口号
bind_ip=127.0.0.1 #IP地址
replSet = child/127.0.0.1:11111 #设定同伴,这里是A
2.初始化副本集
使用shell进入一台服务器,然后设定初始化副本集
use admin
db.runCommand({"replSetInitiate":
{
"_id":'child',
"members":[{
"_id":,
"host":"127.0.0.1:11111"
},{
"_id":,
"host":"127.0.0.1:22222"
},{
"_id":,
"host":"127.0.0.1:33333"
}]
}
})
哪个节点成为活跃节点,这时候是随机的,如果想要更准确的设置,需要设置权重
3.查看副本集状态
rs.status()
上图可以看到,端口为11111的服务器被选择为活跃服务器
注意:
备份点不能进行查询操作的,只有活跃点才能进行查询操作
①在活跃服务器上添加一个数据库并添加一个文档
child:PRIMARY> show dbs
admin (empty)
local 4.076GB
child:PRIMARY> use Students
switched to db Students
child:PRIMARY> db.student.insert({name:"BigOrange",age:25})
WriteResult({ "nInserted" : 1 })
child:PRIMARY> db.student.find()
{ "_id" : ObjectId("56fa6b9159b5751566c1c37f"), "name" : "BigOrange", "age" : 25
}
child:PRIMARY>
②切换到其中一个备份服务器,发现不能进行查询
C:\Windows\system32>mongo 127.0.0.1:22222/test
MongoDB shell version: 2.6.5
connecting to: 127.0.0.1:22222/test
child:SECONDARY> show dbs
Students 0.078GB
admin (empty)
local 2.077GB
child:SECONDARY> use Students
switched to db Students
child:SECONDARY> show collections
2016-03-29T19:50:09.064+0800 error: { "$err" : "not master and slaveOk=false", "
code" : 13435 } at src/mongo/shell/query.js:131
child:SECONDARY> db.student.find()
error: { "$err" : "not master and slaveOk=false", "code" : 13435 }
child:SECONDARY>
补充:
节点和初始化高级参数
standard 常规节点:参与投票有可能成为活跃节点
passive 副本节点:参与投票,但是不能成为活跃节点
arbiter 仲裁节点:只是参与投票不复制节点也不能成为活跃节点
高级参数
Priority 0到1000之间 ,0代表是副本节点 ,1到1000是常规节点
arbiterOnly : true 仲裁节点
用法
把上面A设置为仲裁节点
其他的不变,在初始化的时候,写成如下
use admin
db.runCommand({"replSetInitiate":
{
"_id":'child',
"members":[{
"_id":,
"host":"127.0.0.1:11111",
arbiterOnly : true
},{
"_id":,
"host":"127.0.0.1:22222",
},{
"_id":,
"host":"127.0.0.1:33333"
}]
}
})
其他使用可以参考如下
http://blog.itpub.net/29254281/viewspace-1176553/
4.读写分离操作→扩展读
设置读写分离
slaveOkay : true
MongoDB的主从复制和副本集的更多相关文章
- MongoDB之主从复制和副本集(四)
简单主从复制 采用一主一从或一主多从的布署模式,可以将读写分离开来,提高数据库的可用性,不过mongodb的主从模式并不能在主节点崩溃后,从节点替换主节点的工作,一般可以在开发阶段使用. 实现步骤 设 ...
- MongoDB主从复制和副本集
MongoDB有主从复制和副本集两种主从复制模式,主从复制最大的问题就是无法自动故障转移,MongoDB副本集解决了主从模式无法自动故障转义的特点,因此是复制的首选.对于简单的主从复制无法自动故障转移 ...
- MongoDB 删除,添加副本集,并修改副本集IP等信息
MongoDB 删除,添加副本集,并修改副本集IP等信息 添加副本,在登录到主节点下输入 rs.add("ip:port"); 删除副本 rs.remove("ip:po ...
- MongoDB 带访问控制的副本集部署
当你需要用到一个MongoDB 副本集集群,用于开发测试时, 可以通过下面的步骤简单完成. 版本及环境 MongoDB4.4 Centos6.5 一. 下载安装 MongoDB Server 及 ...
- 8.MongoDB系列之创建副本集(一)
1. 复制简介 在MongoDB中,创建副本集后就可以使用复制功能了,副本集是一组服务器,其中一个是用于处理写操作的主节点,还有多个用于保存主节点的数据副本的从节点,如果主节点崩溃了,则从节点会从中选 ...
- Mongodb主从复制 及 副本集+分片集群梳理
转载努力哥原文,原文连接https://www.cnblogs.com/nulige/p/7613721.html 介绍了Mongodb的安装使用,在 MongoDB 中,有两种数据冗余方式,一种 是 ...
- MongoDB 3.0 常见集群的搭建(主从复制,副本集,分片....)
一.mongodb主从复制配置 主从复制是mongodb最常用的复制方式,也是一个简单的数据库同步备份的集群技术,这种方式很灵活.可用于备份,故障恢复,读扩展等. 最基本的设置方式就是建立一个主节 ...
- MongoDB 学习笔记(七):主从复制与副本集
一.主从复制 1.主从复制是一个简单的数据库同步备份的集群技术,如下图:要明确的知道主服务器与从服务器,且从服务器要明确的知道主服务器的存在. 2.在MongoDB中在启动数据库服务时,可以用mast ...
- Mongodb 主从复制与副本集实验
1.实验主从复制,并验证复制成功,抓图实验过程 Step1:创建相应的目录 Mkdir -p ./dbs/master Mkdir -p ./dbs/slave Step2:开启主服务 ./bin/ ...
随机推荐
- how to learn device driver
making a linux usb driver http://www.kroah.com/linux/ http://matthias.vallentin.net/blog/2007/04/wri ...
- android 链接蓝牙不稳定的解决建议
My workaround I scan BLE for a short period of time 3-4 seconds then I turn scan OFF for 3-4 seconds ...
- 配置nginx,支持php的pathinfo路径模式
nginx模式默认是不支持pathinfo模式的,类似index.php/index形式的url会被提示找不到页面.下面的通过正则找出实际文件路径和pathinfo部分的方法,让nginx支持path ...
- UVa 127 - "Accordian" Patience
题目:52张扑克,从左到右在平面上排列,按着如下规则处理: 1.按照从左到右的顺序,如果一张牌和左边的第一张或者第三张匹配,就把它放到对应的牌上面. 2.如果可以移动到多个位置,移动到最左端的牌上面. ...
- python os.path模块--转载
os.path.abspath(path) #返回绝对路径 os.path.basename(path) #返回文件名 os.path.commonprefix(list) #返回list(多个路径) ...
- Python中raw字符串与多行字符串
如果一个字符串包含很多需要转义的字符,对每一个字符都进行转义会很麻烦.为了避免这种情况,我们可以在字符串前面加个前缀r ,表示这是一个 raw 字符串,里面的字符就不需要转义了.例如: r'\(~_~ ...
- 教你50招提升ASP.NET性能(十二):在生产环境,仔细考虑你需要记录哪些日志
(18)When in production, carefully consider what you need to log 招数18: 在生产环境,仔细考虑你需要记录哪些日志 Many peopl ...
- Lotus分析
一 Lotus的任务 Lotus是一个消息通知服务,topic和subscription是多对多的关系.后面我加了一个发送自定义邮件和自定义短信的功能. 产品里面有个监控报警和通知列表.监控报警里创建 ...
- C++中str1::function和bind
在C++的TR1中(TechnologyReport)中包括一个function模板类和bind模板函数,使用它们能够实现类似函数指针的功能,但却却比函数指针更加灵活,特别是函数指向类的非静态成员函数 ...
- 【10】令operator=返回一个reference to *this
1.令operator= 返回一个reference to *this,为什么? 这只是一个协议,并无强制性.但是,为了与基本类型的行为保持一致性,强烈建议这么做.设计class 有一个宝典:一旦有疑 ...