在一个复制集当中 , 每个节点都需要具备独立的进程 , 所以要分别进行配置
这里需要用到几个重要的配置项

  • replSet - 复制集的名称 , 不同节点设置的复制集名称必须一致 , 才能保证这些节点被加入到同一个复制集当中
  • oplogSize - 复制集的缓存大小 , 单位MB
    ( 不同的节点之间是通过oplog进行同步的 )

当然 , 如果要在一台机器上模拟一个复制集 , 对于每个节点的实例需要配置不同的端口号

步骤

  1. 编写配置文件 , 并启动多个实例
  2. 连接其中一个节点 , 执行配置
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    config = {
    _id:"TestReplSet",//复制集的唯一标识
    members:[
    //复制集当中的成员
    {_id:0,host:"127.0.0.1:28001"},
    {_id:1,host:"127.0.0.1:28002"},
    {_id:2,host:"127.0.0.1:28003",
    arbiterOnly:true
    //置为仲裁节点
    }
    ]
    }

这里是相当于定义了一个名为config的全局变量
其他的节点配置项

  • priority - 值为整数 ( 0~1000 ) , 默认是1 , 代表这个节点的权重 , 也就是成为主节点的机会 , 如果是0则永远不会成为主节点
  • hidden - 是否是隐藏节点 , true/false , 如果设置为true , 那么priority必须是0
  • vote - 整数值 , 该节点是否具有投票权 , 值为0或1
  • slaveDelay - 整数值 , 延迟时间复制数据 , 单位是秒 ( 对于一些误操作 , 可以利用延时挽回数据的损失 )
  1. 执行复制集的初始化
    1
    rs.initiate(config)

稍等片刻即可完成复制集的搭建了