- Oplog的扩容 :
- 背景:一个由3个节点组成的复制集。
- 主节点:A 从节点:B,C
- 需求:Oplog扩容,尽量少的影响业务。
- 思路:先由从节点开始,一台一台的从复制集中剥离,修改,再回归复制集,最后操作主节点来减少业务影响时间。
- 流程:
- 先将B节点关闭,去掉–replSet启动参数,更换启动端口–port,将节点以单机模式启动。
- 然后备份其现有的oplog:
- mongodump –db local –collection ‘oplog.rs’ –port 37017
- 进入mongo,将现在的oplog中最新的位置复制到tmp表(local数据库)中:
- use local
- db.temp.save( db.oplog.rs.find( { }, { ts: 1, h: 1 } ).sort( {$natural : -1} ).limit(1).next() )
- db.temp.find()
- db.oplog.rs.drop()
- 建立新的oplog(capped),下例为2G大小,可根据需求修改:
- db.runCommand( { create: “oplog.rs”, capped: true, size: (2 * 1024 * 1024 * 1024) } )
- db.oplog.rs.save( db.temp.findOne() )
- db.oplog.rs.find()
- 关闭B节点,并恢复原有config配置,并在config中设置oplogSize为你之前设置的大小,并启动。
- 继续对C节点进行如上操作,C节点完成后最后对主节点A进行如上操,作即可完成。
转载于:https://www.cnblogs.com/leochenliang/p/8796227.html