mongoDB 学习笔记(七)主重复制、副本集

主重复制

主从复制是一个简单的数据库同步备份的集群技术

在数据库集群中要明确的知道谁是主服务器,主服务器只有一台.
从服务器要知道自己的数据源也就是对于的主服务是谁.
--master用来确定主服务器,--slave 和 –source 来控制曾服务器

1、简单入门Demo

首先在C:\Users\Administrator\Desktop\mongodb建立8888和7777文件夹

主库配置文件:

8888.conf

dbpath = C:\Users\Administrator\Desktop\mongodb\8888   #主数据库地址
port = 8888 #主数据库端口号
bind_ip = 127.0.0.1 #主数据库所在服务器
#master = true #确定我是主服务器

从库配置文件:

7777.conf

dbpath = C:\Users\Administrator\Desktop\mongodb\7777   #从数据库地址
port = 7777 #从数据库端口号
bind_ip = 127.0.0.1 #从数据库所在服务器
source = 127.0.0.1:8888 #确定我数据库端口
#这个配置项(source)可以用shell动态添加
slave = true #确定自己是从服务器

启动主库添加数据:

启动从库查询数据,从服务器就自动复制主服务器的数据:

 

2、主从复制的其他设置项
--only  配置从节点=》指定复制某个数据库,默认是复制全部数据库
--slavedelay  配置从节点=》设置主数据库同步数据的延迟(单位是秒)
--fastsync 配置从节点=》以主数据库的节点快照为节点启动从数据库
--autoresync 配置从节点=》如果不同步则从新同步数据库
--oplogSize  配置主节点=》设置oplog的大小(主节点操作记录存储到local的oplog中)

 

3、利用shell动态添加和删除从节点

从节点中关于主节点的信息全部存到local的sources的集合中,只要对集合进行操作就可以动态操作主从关系。

//挂接主节点:操作之前只留下从数据库服务
db.sources.insert({“host”:”127.0.0.1:8888”})
//删除已经挂接的主节点:操作之前只留下从数据库服务
db.sources.remove({“host”:”127.0.0.1:8888”}) 

 

副本集

概念

第一张图表明A是活跃的B和C是用于备份的
第二张图当A出现了故障,这时候集群根据权重算法推选出B为活跃的数据库
第三张图当A恢复后他自动又会变为备份数据库

 

副本集的配置

服务器A

dbpath = D:\sortware\mongod\02\A
port = 1111  #端口
bind_ip = 127.0.0.1 #服务地址
replSet = child/127.0.0.1:2222 #设定同伴

服务器B

dbpath = D:\sortware\mongod\02\B
port = 2222
bind_ip = 127.0.0.1
replSet = child/127.0.0.1:3333

 服务器C

dbpath = D:\sortware\mongod\02\C
port = 3333
bind_ip = 127.0.0.1
replSet = child/127.0.0.1:1111

副本集初始化命令

use admin
db.runCommand({"replSetInitiate":
   {
      "_id":'child',
       "members":[{
	        "_id":1,
		"host":"127.0.0.1:1111"
	    },{
		"_id":2,
		"host":"127.0.0.1:2222"
	    },{
		"_id":3,
		"host":"127.0.0.1:3333"
	    }]
    }
})

查看副本集状态,只有在主服务器查看

rs.status()

主从服务器查看

 

副本集的特性

1、shell演示

刚刚启动2222服务器为主服务器,1111和3333为从服务器

关闭2222服务器查看

1111被推选成主服务器

重新启动2222服务器发现2222服务器是从服务器

 

2、.节点和初始化高级参数
     standard 常规节点:参与投票有可能成为活跃节点
     passive 副本节点:参与投票,但是不能成为活跃节点
     arbiter 仲裁节点:只是参与投票不复制节点也不能成为活跃节点

     Priority  0到1000之间 ,0代表是副本节点 ,1到1000是常规节点,数字代表权重,数字越大权重越高
     arbiterOnly : true 仲裁节点

    可以在在副本集初始化的时候添加

members":[{
"_id":1,
"host":"127.0.0.1:1111“,
arbiterOnly : true
}]”

 

3、在优先级相同的时候优先选择更新时间短的数据库

4、读写分离操作
    一般情况下作为副本的节点是不能进行数据库读操作的,但是 slaveOkay参数设置成true主节点进行写操作,从节点进行读操作。在shell中无法演示,这个特性是被写到mongoDB的驱动程序中的,在java和node等其他语言中可以完成。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值