MongoDB数据库修复的操作是怎样,要多久
Admin 2022-06-09 群英技术资讯 852 次浏览
1、首先停止mongodb服务,删除mongodb.log,也可以备份一下
# rm -rf /data/mongodb/mongodb.log
2、删除mongodb进程文件
# rm -rf /mongodb/mongod.lock
3、进行修复
# /usr/local/mongodb/bin/mongod --repair --dbpath /mongodb/ --repairpath /mongodb/repair/
如果后台执行
./mongod --repair --dbpath /data/dbdata --repairpath /data/repair/ --logpath /data/dblog/mongodbrepair.log --fork
这时mongodb进程会在/mongodb/repair/ 目录下储存临时的修复数据库文件,文件目录为“$tmp_repairDatabase_0”所以此目录空间要足够大。
生产环境数据库为100G,修复进行了大约3个半小时,在“/mongodb/repair/$tmp_repairDatabase_0"目录下产生了近30G的数据库临时文件,修复完成后数据库临时文件自动清除。
之后开启mongod服务,检查数据库,发现读写正常,mongodb.log没有出现错误。修复OK!
原理是:把数据重新读一遍,然后写到另一个库中
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文主要介绍了关于mongodb主从复制的内容,对于这方面知识点比较感兴趣的小伙伴可以看看这篇,相信这篇文章能帮助到你解决问题。
mongodb和redis的区别:1、两者内存管理机制不同。2、两者支持的数据结构不同。3、性能上Redis优于MongoDB。4、可靠性上MongoDB优于Redis。
MongoDB导入导出数据的工具和方法有什么?一些朋友可能会遇到这方面的问题,对此在下文小编向大家来讲解一下,内容详细,易于理解,希望大家阅读完这篇能有收获哦,有需要的朋友就往下看吧!
MongoDB中find()和findOne()不同:1、findOne()返回的是一个对象;2、findOne()返回的是一个对象,此对象仅是一个满足输入条件的文档。
文本给大家分享的是MongoDB 中聚合统计的内容,主要介绍$SUM表达式。我们在计算总和的使用,经常会使用到$SUM,因此分享一些相关示例给大家作参考,感兴趣的朋友可以了解一下。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008