0

我想停止docker-stack.yml文件中的所有服务,使用新的映像版本号更新文件,然后启动所有服务。为了一起升级它们,以便它们始终都是最新版本。

我该怎么做呢?我宁愿不删除网络和卷——我的意思是,这docker stack rm似乎有点矫枉过正?并且docker service scale service-name=0感觉容易出错?然后需要记住再次更改回> 0。

我想做一个停止一切升级的原因是它更简单:我的应用程序中的服务不需要与彼此不同版本的 API 兼容。永远不会有版本 X 的服务正在运行并且必须与另一个服务的版本 X - 1 通信(相反,所有服务都将使用相同的版本 X。它们使用相同的版本号)。

(如果我问错了问题,请随时告诉我 :- ) 注意:在这种特殊情况下,20 - 30 秒的停机时间是可以的,因为所有容器都会立即停止-升级-重新启动。这适用于 Docker Swarm / Stack,而不是 Docker-Compose(然后可以只做downand up)。)

4

1 回答 1

1

免责声明:我觉得这是错误的升级方法。它将停机时间引入设计为高度可用的系统中。


要停止服务,我可能会添加一个无法满足的约束,例如

docker service update \
  --constraint-add node.label.disable_service==true -d \
  ${service_name}

这涵盖了复制服务和全球预定服务。当您使用 compose 文件重新部署堆栈时,它将删除此约束(它还应该删除任何比例更改)。


如果您的堆栈像您描述的那样紧密耦合,那么接近蓝/绿部署的东西可能是更好的选择。在连接到两个 docker 网络的服务前面放置一个代理,然后在其中一个网络上启动蓝色或绿色堆栈。然后替换它,启动另一个网络上的另一个堆栈,一旦运行并且代理正在路由流量,停止第一个堆栈。

于 2018-11-16T12:12:44.237 回答