一 问题描述

之前做的用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就能正常启动了。

--本篇文章主要参考自:

MongoDB: ERROR: child process failed, exited with error number 14 - Stack Overflow

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐