参考:

3.2修改oplogsize的文档:

mongodb 3.2 修改oplogsize的方法:

1、关闭这个从节点的mongodb进程

1.1 关进程

use admin

db.shutdownServer()

1.2 注销Replica set相关启动参数,并修改port端口号

vim mongod.conf ,注释掉下面几行,然后修改下监听端口

#replication:

#  oplogSizeMB: 4096

#  replSetName: set01

net:

port: 27111

然后,以单实例的方式启动这个从节点:

mongod -f mongod.conf

2、备份节点oplog日志

2.1 全备当前节点的oplog记录

mongodump --port 27111 --db local --collection 'oplog.rs' -o /root/oplog_all

2.2 备份oplog中最后一条记录

mongo  --port 27111

use local

db.optmp.drop()   ---清空临时表,存放oplog最近一条记录

db.optmp.save(db.oplog.rs.find( { }, { ts: 1, h: 1 } ).sort( {$natural : -1} ).limit(1).next() )     ---将最近一条记录存放到临时集合中

db.optmp.find()     ---验证是否记录已存入 , 类似如下:

{ "_id" : ObjectId("5b857e9aaa9ffcbad436b99d"), "ts" : Timestamp(1535468213, 1), "h" : NumberLong("-6700258201084773806") }

3 先删除原oplog.rs集合,然后修改oplogsize:

use local

db.oplog.rs.drop()

然后再创建新oplog.rs集合 ,这里创建为6G

> db.runCommand( { create: "oplog.rs", capped: true, size: (6 * 1024 * 1024 * 1024) } )

{ "ok" : 1 }

> db.oplog.rs.stats().maxSize   # 可以看到变成6G了

NumberLong("6442450944")

4、还原之前备份的最近一条记录

> db.oplog.rs.save(db.optmp.findOne())

> db.oplog.rs.find()          ---查询验证是否已插入

5、关闭当前单实例进程,然后修改配置,重新加入副本集

> use admin

> db.shutdownServer()

vim mongod.conf ,注释掉下面几行,然后修改下监听端口

net:

port: 27017

replication:

oplogSizeMB: 6144

replSetName: set01

mongod -f mongod.conf

6、检查节点状态

登录到mongo shell中检查节点是否成功加入副本集

> rs.status()

检查oplogSize是否生效

set01:SECONDARY> db.getReplicationInfo()

{

"logSizeMB" : 6144,    ## 可以看到这里变成6GB了

"usedMB" : 0.01,

"timeDiff" : 54,

"timeDiffHours" : 0.02,

"tFirst" : "Wed Aug 29 2018 01:19:49 GMT+0800 (CST)",

"tLast" : "Wed Aug 29 2018 01:20:43 GMT+0800 (CST)",

"now" : "Wed Aug 29 2018 01:24:16 GMT+0800 (CST)"

}

set01:SECONDARY> rs.printReplicationInfo()

configured oplog size:   6144MB

log length start to end: 54secs (0.02hrs)

oplog first event time:  Wed Aug 29 2018 01:19:49 GMT+0800 (CST)

oplog last event time:   Wed Aug 29 2018 01:20:43 GMT+0800 (CST)

now:                     Wed Aug 29 2018 01:24:41 GMT+0800 (CST)

在4.0里面,支持在线修改oplog的大小,从而不用重启:

db.adminCommand({replSetResizeOplog:1, size: 6144})        ## 设置为6GB, 注意这里的单位是 mb

use local

db.oplog.rs.stats().maxSize

4.0在线修改oplogsize的官方文档:https://docs.mongodb.com/manual/reference/configuration-options/index.html#replication.oplogSizeMB

附, 如何估算需要的oplogsize大小?

可以通过如下的命令查看当前的oplog能存放多久的操作记录:

    connecting to: 127.0.0.1:27017/admin

    set01:SECONDARY> rs.printReplicationInfo()

    configured oplog size:   4096MB

    log length start to end: 6223secs (1.73hrs)

    oplog first event time:  Mon Apr 22 2019 12:53:49 GMT+0800 (CST)

    oplog last event time:   Mon Apr 22 2019 14:37:32 GMT+0800 (CST)

    now:                     Mon Apr 22 2019 14:37:32 GMT+0800 (CST)

可以看到,目前的oplog是4GB ,根据oplog first event time 和 oplog last event time 的差值,可以得出4g的oplog 差不多能存放 100分钟 的op操作。

如果我们将oplogsize扩大到 20G ,差不多能存放 500分钟 的op操作。(即最大能容忍8小时的某个节点的宕机)