MongoDB服务1053错误、1067错误处理

起因

本人的MongoDB服务在windows服务器运行,且一直有读写的操作。因为服务器突然断电导致出错,再次重启服务器后无法正常运行MongoDB服务。

查阅了网上的众多资料后觉得实在很碎片化,于是记录下自己遇到的问题和解决成功的办法,如果你同样遇到了意外断开MongoDB服务(尤其是有读写操作运行的时候),那么极有可能遇到这两个错误,希望对你有用。

解决问题1:无法启动MongoDB服务

使用命令行工具或者windows服务启动MongoDB遇到如下报错,无法启动:

这个错误的解决办法很简单:删除该服务并重新创建一个服务。 MongoDB服务相当于注册表的一条命令,并不影响本地的数据,可以随便进行删除和重新创建。

  1. 删除原有的MongoDB服务
cmd 复制代码
 sc.exe delete MongoDB
  1. 创建新的MongoDB服务 这个方式有多种,一般分为两种创建的方式:
  • 一种直接命令输入指定数据库的存储路径 dbpath(可以有本地数据,不会影响) 和日志的路径logpath
  • 另一种则是使用config文件(位于MongoDB安装目录的bin目录下的mongod.cfg文件,一般位于C:\Program Files\MongoDB\Server\5.0\bin>),在config文件里面写入配置如数据库存储路径和日志,以及是否开启安全验证等,这样就可以避免多次直接在命令行中输入路径

为了方便使用,这里我们编辑一个简单的cfg文件(也可以编辑原本的mongod.cfg),在其中写入路径配置

cfg 复制代码
##数据文件
dbpath=E:\MongoDB\data

##日志文件
logpath=E:\MongoDB\log\mongo.log

然后在当前的bin目录下运行以下命令,表示按照config创建一个MongoDB服务。

cmd 复制代码
 mongod.exe --config "C:\Program Files\MongoDB\Server\5.0\bin\mongod.cfg" --install --serviceName "MongoDB" --serviceDisplayName "MongoDB"

创建成功是没有返回结果的,此时可以通过任务管理器-服务-打开服务-MongoDB)看到在启动的状态。

  1. 尝试启动MongoDB 这里可以可以尝试启动一下,如果直接可以启动说明数据库没有数据文件损坏。如果没有什么数据文件,推荐可以直接在新的文件夹下存储数据,也就是将dbpath路径置为新的文件夹。
cmd 复制代码
net start MongoDB

解决问题2: 进程意外错误

这个问题有多个原因,网上的处理方式一般是不针对数据受损的情况的,如果数据不受损,那么可以直接将dbpath路径下的mongod.lock文件删除(锁文件,不影响实际数据),然后再次使用net start命令启动,如果还是不行那么考虑数据受损的情况,那就使用repair命令修复。

使用repair命令,扫描所有的本地数据修复(耗时长)

(使用前删除lock文件)

该命令是MongoDB专门应对数据文件受损的一种修复机制,原理是删除所有搜索的索引和数据文档。所以最好在运行该命令前对数据文件进行备份!

直接在MongoDB的bin目录下运行以下命令:

cmd 复制代码
mongod.exe --dbpath E:\MongoDB\data --repair

该命令会对dbpath中的所有的数据文件进行扫描、检查、索引的重构。如果数据量大的话,时间耗费也会很久。参考本人千万级别的数据文档,运行了近一天一夜才结束。

在结束后会详细报告修复的集合。

最后运行执行启动MongoDB,这次一般都可以顺利进行执行。

cmd 复制代码
net start MongoDB

最后一定不要随便给正在读写的MongoDB数据库意外断开!!

相关推荐
心态还需努力呀43 分钟前
不止于 MongoDB 替代:金仓数据库多模一体的技术实践与性能实测
数据库·mongodb
正在走向自律1 小时前
KingbaseES数据库MongoDB兼容模式实战:协议级兼容实现业务平滑迁移
数据库·mongodb·国产数据库·kingbasees·电科金仓
倔强的石头1061 天前
多模融合重塑文档数据库:金仓数据库 MongoDB 兼容版的技术实践
数据库·mongodb·kingbase
Gary董2 天前
redis 和 mongoDB 的优劣
数据库·redis·mongodb
数据知道3 天前
一文掌握 MongoDB 详细安装与配置(Windows / Linux / macOS 全平台)
linux·数据库·windows·mongodb·macos
茁壮成长的露露4 天前
MongoDB分片案例
数据库·mongodb
chalmers_154 天前
MongoDB实现发布订阅机制
数据库·mongodb
2401_863318635 天前
基于RS-232C的串口通信
数据库·mongodb
茁壮成长的露露6 天前
pbm物理备份恢复
数据库·mongodb
DBA小马哥6 天前
文档型数据库MongoDB迁移替换至金仓数据库在电商商品信息存储中的应用
数据库·mongodb