一、环境
Host:CentOS 7.9
Version:MongoDB 5+
Install:二进制
二、说明
公司某天电闸突然跳闸,导致服务器重启后,伴随的自启动服务(MongoDB)启动失败,具体报错如下所示。
三、排查
1、查看启动状态
systemctl status mongodb.service
...
mongodb child process failed, exited with error number 51
...
2、复制错误信息网上搜集资料
通过查阅资料得知是这个异常大部分是因为 mongodb 服务的不正常关闭导致文件损坏,于是需要进行文件修复。
四、解决方案
1、删除 .pid、.lock 文件
rm -rf /data/mongodb/data/mongod.pid
rm -rf /data/mongodb/data/mongod.lock
2、修复损坏文件
mongod -f mongodb.conf --repair
...
..succusesfull !!..
...
3、重启 MongoDB 服务
systemctl restart mongodb.service
4、查看进程
[root@localhost ~]# ps -ef |grep mong
root 19035 1 0 1月17 ? 00:12:02 /opt/mongodb5.0.5/bin/mongod --config /opt/mongodb5.0.5/mongodb.conf
# 或查看端口
[root@localhost ~]# netstat -lntp | grep 8090
tcp 0 0 0.0.0.0:8090 0.0.0.0:* LISTEN 19035/mongod
至此,问题已解决!!