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数据库意外断开!!

相关推荐
知识分享小能手8 小时前
MongoDB入门学习教程,从入门到精通,MongoDB入门指南 —— 知识点详解(2)
数据库·学习·mongodb
vpk11213 小时前
使用 Docker Compose 快速安装 MongoDB
mongodb·docker·容器
爬山算法16 小时前
MongoDB(55)如何监控分片集群?
数据库·mongodb
vpk11218 小时前
Docker Compose 部署 Yapi(连接本地MongoDB)
mongodb·docker·yapi
jianqiang.xue2 天前
ESP32-S3 运行 Linux 全指南:从 RISC-V 模拟器移植到 8 秒快速启动
linux·stm32·单片机·mongodb·risc-v·esp32s3
知识分享小能手2 天前
MongoDB入门学习教程,从入门到精通,MongoDB 知识点详解(1)
数据库·学习·mongodb
爬山算法4 天前
MongoDB(52)如何配置分片?
数据库·mongodb
2401_858936885 天前
51 单片机核心知识点:GPIO、中断、定时器与蜂鸣器驱动
单片机·mongodb·nosql
爬山算法5 天前
MongoDB(50)副本集中的角色有哪些?
数据库·mongodb
Predestination王瀞潞6 天前
4.1.1 存储->数据库:MongoDB
数据库·mongodb