docker - 如何更改 Docker 堆栈重启行为?
问题描述
在我们的项目中,我们继承了包含一些服务堆栈的 Docker 环境。
我注意到 Docker 一旦面临内存限制就会重新启动堆栈。
不幸的是,根据我在 Docker 网站上的问题,我没有找到任何信息,所以我在这里问:
- 这种行为是可配置的吗?例如,我不希望 Docker 在任何情况下都重新启动我的堆栈。如果它是可配置的,那么如何配置?
- 是否有任何 docker 日志来保持任何堆栈在其条目时重新启动?
解决方案
- 这种行为是可配置的吗?例如,我不希望 Docker 在任何情况下都重新启动我的堆栈。如果它是可配置的,那么如何配置?
使用版本 3 堆栈,重新启动策略移至部署部分:
version: '3'
services:
crash:
image: busybox
command: sleep 10
deploy:
restart_policy:
condition: none
# max_attempts: 2
有关这方面的文档,请访问:https ://docs.docker.com/compose/compose-file/#restart_policy
- 是否有任何 docker 日志来保持任何堆栈在其条目时重新启动?
根据任务历史限制(可配置docker swarm update
),您可以查看服务之前运行的任务:
$ docker service ps restart_crash
ID NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR PORTS
30okge1sjfno restart_crash.1 busybox:latest bmitch-asusr556l Shutdown Complete 4 minutes ago
papxoq1vve1a \_ restart_crash.1 busybox:latest bmitch-asusr556l Shutdown Complete 4 minutes ago
1hji2oko51sk \_ restart_crash.1 busybox:latest bmitch-asusr556l Shutdown Complete 5 minutes ago
您可以检查任何一项任务的状态:
$ docker inspect 30okge1sjfno --format '{{json .Status}}' | jq .
{
"Timestamp": "2018-11-06T19:55:02.208633174Z",
"State": "complete",
"Message": "finished",
"ContainerStatus": {
"ContainerID": "8e9310bde9acc757f94a56a32c37a08efeed8a040ce98d84c851d4eef0afc545",
"PID": 0,
"ExitCode": 0
},
"PortStatus": {}
}
Docker 引擎中还有一个事件历史记录,您可以查询:
$ docker events --filter label=com.docker.swarm.service.name=restart_crash --filter event=die --since 15m --until 0s
2018-11-06T14:54:09.417465313-05:00 container die f17d945b249a04e716155bcc6d7db490e58e5be00973b0470b05629ce2cca461 (com.docker.stack.namespace=restart, com.docker.swarm.node.id=q44zx0s2lvu1fdduk800e5ini, com.docker.swarm.service.id=uqirm6a8dix8c2n50thmpzj06, com.docker.swarm.service.name=restart_crash, com.docker.swarm.task=, com.docker.swarm.task.id=1hji2oko51skhv8fv1nw71gb8, com.docker.swarm.task.name=restart_crash.1.1hji2oko51skhv8fv1nw71gb8, exitCode=0, image=busybox:latest@sha256:2a03a6059f21e150ae84b0973863609494aad70f0a80eaeb64bddd8d92465812, name=restart_crash.1.1hji2oko51skhv8fv1nw71gb8)
2018-11-06T14:54:32.391165964-05:00 container die d6f98b8aaa171ca8a2ddaf31cce7a1e6f1436ba14696ea3842177b2e5e525f13 (com.docker.stack.namespace=restart, com.docker.swarm.node.id=q44zx0s2lvu1fdduk800e5ini, com.docker.swarm.service.id=uqirm6a8dix8c2n50thmpzj06, com.docker.swarm.service.name=restart_crash, com.docker.swarm.task=, com.docker.swarm.task.id=papxoq1vve1adriw6e9xqdaad, com.docker.swarm.task.name=restart_crash.1.papxoq1vve1adriw6e9xqdaad, exitCode=0, image=busybox:latest@sha256:2a03a6059f21e150ae84b0973863609494aad70f0a80eaeb64bddd8d92465812, name=restart_crash.1.papxoq1vve1adriw6e9xqdaad)
2018-11-06T14:55:00.126450155-05:00 container die 8e9310bde9acc757f94a56a32c37a08efeed8a040ce98d84c851d4eef0afc545 (com.docker.stack.namespace=restart, com.docker.swarm.node.id=q44zx0s2lvu1fdduk800e5ini, com.docker.swarm.service.id=uqirm6a8dix8c2n50thmpzj06, com.docker.swarm.service.name=restart_crash, com.docker.swarm.task=, com.docker.swarm.task.id=30okge1sjfnoicd0lo2g1y0o7, com.docker.swarm.task.name=restart_crash.1.30okge1sjfnoicd0lo2g1y0o7, exitCode=0, image=busybox:latest@sha256:2a03a6059f21e150ae84b0973863609494aad70f0a80eaeb64bddd8d92465812, name=restart_crash.1.30okge1sjfnoicd0lo2g1y0o7)
在以下位置查看有关 events 命令的更多详细信息:https ://docs.docker.com/engine/reference/commandline/events/
大型组织的最佳实践是将容器日志发送到中央位置(例如 Elastic)并在外部监控指标(例如 Prometheus/Grafana)。
推荐阅读
- swagger - 我可以简单地渲染一个 swagger.yaml 文件吗?
- python - 如何将参数列表传递给函数,以便它在python中按顺序执行(而不是同时在列表的所有元素上)?
- java - http请求中的Spring启动时区
- c++ - 如何在 C++ 中取消引用指针对象?
- ruby - select2 在带有支架的 rails 6 中不起作用
- java - java - 如何在时间间隔后使用log4j2或java中的logback批量收集日志并将其写入文件
- c# - 将对象转换为字典
- c++ - 从 Sqlite 数据库中检索到的行创建对象
- mysql - 当数据主要通过连接访问时,是否应该进行非规范化?
- c - 以十六进制显示宽字符显示意外结果