如何解决更新后容器始终在docker-compose.yml中没有重新启动并重新启动
我有一些容器,它们全部在docker-compose文件中具有始终重启的值,如下所示:
version: "3.7"
services:
container:
image: ghost:latest
container_name: some_container
restart: always
depends_on:
- ...
ports:
- ...
...
一旦操作系统(Flatcar Linux / CoreOS)进行了自我更新,所有容器均不会重启。但是,如果我只是$ sudo docker ps
,则所有容器都将立即启动。怎么了,我该如何解决,以便我的容器在更新后自动重新启动?
编辑:
不确定我的问题有哪些不清楚之处,restart: always
已打开。除非我在文档中缺少一些重要的内容,否则即使重启docker守护进程(在OS重启之后),该命令也应该重启容器。
从下面复制我的评论之一:
好的,请在这里帮助我。如您所见,我有 重新启动:始终打开。所有这些容器已启动 成功并且运行良好。然后,操作系统会自我更新 自动并重新启动。重新启动后,码头工人 守护程序重新启动。但是由于某些原因,我运行的容器
RESTART: ALWAYS
打开时无法启动。如果我输入服务器 此时,输入sudo docker ps
列出我正在运行的容器, 突然所有的容器都启动了,我看到了列表。所以为什么 即使守护程序正在运行,容器也没有启动吗?
解决方法
从注释中看来,docker服务未配置为在引导时自动启动。 Docker是一个客户端服务器应用程序,服务器从systemd运行,并为客户端用于与服务器通信的docker套接字提供单独的服务。因此,使用docker命令进行的任何调用都有可能通过敲击docker套接字来启动服务器。
可以使用以下命令检查systemd中的服务状态:
sns.set()
fig,ax = plt.subplots(figsize=(8,4))
sns.boxplot(x='household',y='value',hue='phase',data=VoltageProfileFile_long,ax=ax)
plt.title('Boxplot of Values by Household and Phases')
plt.tight_layout()
plt.show()
plt.clf()
plt.close()
或者您可能要检查:
systemctl status docker
可以通过以下方式手动启动:
systemctl is-enabled docker
并且可以将其开头为:
systemctl start docker
以上所有命令都必须以root用户身份运行。
,这要求Docker服务必须在启动时启动,而不是使用默认的套接字激活来启动,就像您通过执行“ docker ps”描述的那样按需启动
这是在禁用套接字激活时启用Docker服务所需的Container Linux Config:
systemd:
units:
# Ensure docker starts automatically instead of being socket-activated
- name: docker.socket
enabled: false
- name: docker.service
enabled: true
,
always
如果容器停止,请始终重新启动它。如果手动停止,则仅在Docker守护进程重启或容器本身手动重启时才重新启动。
unless-stopped
与always
相似,除了容器停止(手动或其他方式)时,即使重新启动Docker守护程序也不会重新启动容器。
如果您有一个要更改其重启策略的容器,可以使用docker update command
进行更改,下面的命令将确保所有当前正在运行的容器将被重启,除非停止了>
$ docker update --restart unless-stopped $(docker ps -q)
注意:使用重启策略时请注意以下几点
-
重新启动策略仅在容器成功启动后才生效。在这种情况下,成功启动意味着该容器已启动至少10秒钟,并且Docker已开始对其进行监视。这样可以防止根本无法启动的容器进入重启循环。
-
如果您手动停止容器,则其重新启动策略将被忽略,直到Docker守护程序重新启动,或者手动重新启动容器。这是防止重新启动循环的另一种尝试。
-
重新启动策略仅适用于容器。群服务的重启策略配置不同
这是容器重启策略。 restart: always
如果容器停止,则重新启动它。如果已手动停止,则仅在Docker守护进程重新启动或容器本身手动重新启动时才重新启动。请检查此链接restart_policy。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。