17

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

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

docker-compose 示例

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-compose-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
4

2 回答 2

12

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

当您进行部署时,这取决于您部署到的位置。大多数容器集群,如 kubernetes、mesos 或 ECS 都会有一些配置,您可以使用它来自动重启容器。如果您不使用任何这些工具,您可能是手动启动容器,然后可以像在本地一样使用重启标志。

于 2016-10-18T13:21:56.473 回答
6

在我看来很好。在处理 Docker 策略时,您想要了解的是每个策略的含义。always策略意味着如果它因任何原因崩溃自动重启。

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

那么为什么你会想要使用always而不是说呢on-failure

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

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

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

于 2018-12-22T00:27:47.770 回答