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