MongoDB 非正常关机(拉电闸)后无法启动的解决方案

目录

    • 一、环境
    • 二、说明
    • 三、排查
    • 四、解决方案

一、环境

  • 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

至此,问题已解决!!

你可能感兴趣的:(FAQ,mongodb,数据库,database)