MongoDB中怎么修改oplogSize
发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,这篇文章将为大家详细讲解有关MongoDB中怎么修改oplogSize,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、关闭此节点并以单实例启动1.1
千家信息网最后更新 2025年11月13日MongoDB中怎么修改oplogSize
这篇文章将为大家详细讲解有关MongoDB中怎么修改oplogSize,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
1、关闭此节点并以单实例启动
1.1关闭节点进程
SECONDARY> db.shutdownServer()
1.2注销Replica set相关启动参数
并修改port端口号(假设原来是27001,现改为37001)
1.3 重新启动
/apps/mongodb/bin/mongod -f /data/johnny/cfg/shard1.cnf
2、备份节点oplog日志
全备当前节点的所有oplog记录
mongodump --port 37001 --db local --collection 'oplog.rs'
备份oplog.rs中最近的一条oplog记录
>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("5a0d437ed4738d194fa0b94f"), "ts" : Timestamp(1510389543, 1), "h" : NumberLong("-2633465233485407995") }3、修改oplogSize
删除原oplog.rs集合
>use local>db.oplog.rs.drop()
创建新oplog.rs集合
> db.runCommand( { create: "oplog.rs", capped: true, size: (2 * 1024 * 1024 * 1024) } ){ "ok" : 1 } ---成功的话将返回ok4、还原之前备份的最近一条记录
> db.oplog.rs.save(db.optmp.findOne())> db.oplog.rs.find() ---查询验证是否已插入
5、重新加入副本集
5.1 关闭当前单实例进程
>db.shutdownServer()
5.2 恢复配置文件信息
(注意oplogSizeMB参数值的修改)

5.3 启动实例进程
/apps/mongodb/bin/mongod -f /data/johnny/cfg/shard1.cnf
6、检查节点状态
登录到mongo shell中检查节点是否成功加入副本集架构
>rs.status() 检查oplogSize是否生效(红色字体)SECONDARY> rs.printReplicationInfo()configured oplog size: 2048MBlog length start to end: 0secs (0hrs)oplog first event time: Sat Nov 11 2017 16:39:03 GMT+0800 (CST)oplog last event time: Sat Nov 11 2017 16:39:03 GMT+0800 (CST)now: Thu Nov 16 2017 17:00:32 GMT+0800 (CST)
7、根据上述步骤依次修改副本集的其他成员的oplogSize参数
注:修改Primary节点时,记得先使用如下命令降级,然后再修改
Primary>rs.stepDown() ---可以更有效的产生选举
方法二:
3.6版本后支持的动态修改方法
1.修改之前的参数大小:
replication: oplogSizeMB: 1024 replSetName: shardrs1
登录到mongo shell后查看oplog.rs集合大小
> use localswitched to db local> db.oplog.rs.stats().maxSizeNumberLong(1073741824) ---单位bytes,即2014MB
2.通过管理命令修改
> use localswitched to db local> db.adminCommand({replSetResizeOplog:1, size: 2048}); ---2048的单位也MB{ "ok" : 1, "operationTime" : Timestamp(1537776585, 1), "$clusterTime" : { "clusterTime" : Timestamp(1537776585, 1), "signature" : { "hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="), "keyId" : NumberLong(0) } }}3.验证是否成功
> db.oplog.rs.stats().maxSizeNumberLong("2147483648")至此我们的oplog size动态修改完毕,是不是很简单,是不是很easy?
思考:
问1:replSetResizeOplog命令会不会同时修改了replication.oplogSizeMB参数值呢?
答:我此时查看启动配置文件,发现oplogSizeMB依然是1024;
问2:重启后会不会配置文件中的参数值就更改为修改值了呢?
答:重新启动数据库实例后,我发现并没有,还是最初值
问3:那么重启后,新修改值会失效吗?
答:我再次发现并没有,仍然使用最新值
shardrs1:PRIMARY> db.oplog.rs.stats().maxSizeNumberLong("2147483648")关于MongoDB中怎么修改oplogSize就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
节点
参数
实例
成功
副本
命令
备份
文件
进程
检查
配置
验证
内容
动态
单位
大小
文章
方法
更多
知识
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
若您的网络安全性
字节跳动企业网络服务器
后勤管理软件开发
软件开发出差的利弊
市面主流云服务器
网络技术发展的方向
图数据库 语言
青庭网络技术有限公司
网络安全教育课教案大全
罗盘软件开发
博世中国软件开发中心
数据库设计的三种抽象方法
storm网络安全团队
备份的数据库怎么查看版本
举办网络安全宣传周意义
至强服务器处理器是什么意思
某甲应聘到一软件开发公司
驾校数据库清理
服务器电源 短接
网络安全设计方案
ibmda400数据库
去哪里更改服务器
创建数据库的命令
热血传奇第一服务器
用户所有信息数据库
计算机与网络安全的发展
软件开发阿陈
网络安全感目标是什么
北大软件开发二学位怎样
树莓派软件开发平台