自动崩溃时重新启动 Docker 个容器

Restart Docker Containers when they Crash Automatically

如果容器自动崩溃,我想重新启动它。我不知道该怎么做。我有一个脚本 docker-compose-deps.yml,它有 elasticsearch、redis、nats 和 mongo。我 运行 在终端中设置这个:docker-compose -f docker-compose-deps.yml up -d。在此之后,我通过 运行ning: docker-compose up -d 设置了我的容器。有没有办法让这些容器在崩溃时重新启动?我注意到 docker 有一个内置的重启功能,但我不知道如何实现它。

经过一些反馈后,我将 restart: always 添加到我的 docker-compose 文件和 docker-compose-deps.yml 文件中。这看起来正确吗?还是这就是您始终实施重启的方式?

docker-撰写样本

myproject-server:
  build: "../myproject-server"
  dockerfile: Dockerfile-dev
  restart: always
  ports:
  - 5880:5880
  - 6971:6971
  volumes:
  - "../myproject-server/src:/src"
  working_dir: "/src"
  external_links:
  - nats
  - mongo
 - elasticsearch
 - redis
myproject-associate:
  build: "../myproject-associate"
  dockerfile: Dockerfile-dev
  restart: always
  ports:
  - 5870:5870
  volumes:
  - "../myproject-associate/src:/src"
  working_dir: "/src"
  external_links:
  - nats
  - mongo
  - elasticsearch
  - redis

docker-合成-deps.yml样本

nats:
  image: nats
  container_name: nats
  restart: always
  ports:
  - 4222:4222
mongo:
  image: mongo
  container_name: mongo
  restart: always
  volumes:
  - "./data:/data"
  ports:
  - 27017:27017

如果您使用的是 compose,它有一个重启标志,类似于 docker 运行 命令中存在的标志,因此您可以使用它。这是关于这部分的文档的 link - https://docs.docker.com/compose/compose-file/

何时部署出去,取决于部署到哪里。大多数容器集群(如 kubernetes、mesos 或 ECS)都有一些配置可用于自动重启容器。如果您不使用这些工具中的任何一个,您可能正在手动启动容器,然后可以像在本地一样使用重启标志。

我觉得不错。在制定 Docker 政策时,您想要了解的是每个政策的含义。 always 政策意味着如果它因任何原因崩溃自动重启。

因此,如果它出于任何原因停止,请继续并重新启动它。

那你为什么要使用 always 而不是 on-failure

在某些情况下,您可能有一个始终要确保 运行 的容器,例如 Web 服务器。如果您是 运行 一个 public Web 应用程序,您可能希望该服务器在 100% 的时间内可用。

因此,对于 Web 应用程序,我希望您使用 always。另一方面,如果您是 运行 文件上的工作进程,然后自然退出,这将是 on-failure 策略的一个很好的用例,因为工作容器可能已完成文件处理并且你可能想让它关闭而不是让它重新启动。

这就是我希望使用 on-failure 政策的地方。因此,不仅要了解语法,还要了解何时应用哪种策略以及每种策略的含义。