日期:2014-05-16  浏览次数:20612 次

mongoDB的两个特性:主从复制、副本集

一、主从复制

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

1.1在数据库集群中要明确的知道谁是主服务器,主服务器只有一台.

1.2从服务器要知道自己的数据源也就是对于的主服务是谁.

1.3--master用来确定主服务器,--slave 和 –source 来控制从服务器

1.主从复制集群案例

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”})

二、副本集概念

1.1第一张图表明A是活跃的B和C是用于备份的

1.2第二张图当A出现了故障,这时候集群根据权重算法推选出B为活跃的数据库

1.3第三张图当A恢复后他自动又会变为备份数据库

2.初始化副本集

use admin

db.runCommand({"replSetInitiate":

  {

     "_id":'child',

      "members":[{

     &nb