MongoDB 启动失败 ERROR: child process failed, exited with 1

一 问题描述
之前做的用systemctl方式启动mongo,有一次节点被异常终止,同事手动启动mongo的时候没用systemctl方式起,而是用mongod -f 配置文件这种方式启动的。数据库起来了,但是后来想用systemctl方式关闭数据库,发现无法关闭,用systemctl启动数据库,也起不来了,报错:

ERROR: child process failed, exited with error number 14

我手动用mongo用户执行mongod -f 配置文件也无法启动mongo,也是报一样的错误。

二 出错原因
① 没有正常关闭mongo

不应该用kill -9方式关

② 同事是用root用户执行mongod -f 配置文件方式启动的mongo,所以很多文件的属主是root。但是systemctl调用的service文件里用户是mongo,因此导致无法用systemctl方式启动mongo。

三 解决办法
① 关闭用mongod -f 配置文件启动的数据库时,这样关闭

#进数据库,执行:

use admin;

db.shutdownServer();

② 确保mongo数据文件目录属主是mongo

修改数据文件属主为mongo,示例:

chown -R mongo:mongo /data/mongo

再次启动mongo就能正常启动了。

猜你喜欢

转载自blog.csdn.net/weixin_45839894/article/details/127959295