一、 现象
当我使用docker-compose编排容器时,遇到了一个问题。我的容器一直再restarting,并且状态码为0. 也没有错误日志输出。 如下图所示
二、原因
第一, exit code = 0, 说明部署的images和容器都没有问题,这个是正常退出。
exited code如下:
0,表示正常退出
非0,表示异常退出(退出状态码采用chroot标准)
125,Docker守护进程本身的错误
126,容器启动后,要执行的默认命令无法调用
127,容器启动后,要执行的默认命令不存在
其他命令状态码,容器启动后正常执行命令,退出命令时该命令的返回状态码作为容器的退出状态码
第二,设置的restart出现了问题 ,我设置的restart为always, 所以容器会一直重启。
restart参数如下:
no,默认策略,在容器退出时不重启容器
on-failure,在容器非正常退出时(退出状态非0),才会重启容器
on-failure:3,在容器非正常退出时重启容器,最多重启3次
always,在容器退出时总是重启容器
unless-stopped,在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器
所以,当容器正常退出时,容易会一直重启。所以就导致了restarting
第三, docker容器会自动退出,当我们的任务执行完成时。所以需要设置一个持久的任务
三、解决方案
第一,将restart设置为 no,就不会出现restarting。但这不是根源
第二,关键点,将容器启动时运行的命令设置为长服务,例如我下面的
cmd python app.py