docker启动mongodb一直重启问题
1. mongo 容器 Restarting (132) 2 seconds ago
近期接手一个后端项目,发现使用docker 创建mongodb的容器时,总是显示一直重启,显示Restarting (132) 2 seconds ago
, 然而在我自己的window10电脑上却无法复现,或者换一台机器也不会出现类似的问题。
查了下万能的google 终于找到了问题所在。
原文链接:https://stackoverflow.com/questions/60930359/docker-containers-exit-code-132
主要原因为: 机器不支持avx指令,可以通过cat /proc/cpuinfo | grep avx
or sudo cat /proc/cpuinfo | grep avx
查看你的系统是否支持avx 指令 ,如果有匹配的值说明是支持avx的,如果返回是空的,说明不支持avx。
不支持avx 则可能导致上述mongo容器一致重启的问题,解决办法:
1) 选择一台支持avx指令的机器,就可以解决了 。
2) 将mongo 的版本下调至4.4版本。因为最新的mongo只能在支持amd64-avx的机器上运行,而4.4的版本可以在没有avx的机器运行的 ( 例如:docker pull mongo:4.4 )
2. mongo 容器 Restarting (62) 2 seconds ago
这里我拉了一个mongo:4.4的镜像,然后尝试了下启动容器,发现另一个报错信息: Restarting (62) 2 seconds ago
, 于是查了下docker exit code 62的说明, 找到了问题所在:
原文链接:https://stackoverflow.com/questions/47850004/mongodb-shutting-down-with-code62
主要原因为新版本4.4的mongo和之前mongo(最新版)的数据存在冲突,因此删除之前MongoDB 存储的数据即可。
例如我这里的路径是 ./mongodb_data
,直接rm -r ./mongodb_data/*
。删除之后在使用docker启动容器就没有问题了。