docker swarm如何让两个副本分别跑在两台不同的主机上

embedded/2024/10/9 7:46:43/

虽然 docker swarm 支持自动扩容部署,但是为了服务的稳定性、可靠性,有的时候甲方巴巴会要求一定要服务分散部署在不同的服务器上。
使用默认的部署方式,虽然副本为 N,但是部署的 N 个服务可能落在同一台服务器上。
在 Docker Swarm中,要让服务(service)的两个副本(replica)分别运行在不同的主机上,你需要做的是在部署服务时,使用 --constraint 标志来指定资源限制,例如主机的标签(labels)等都是可以的。

首先,确保你的两台主机已经加入到Docker Swarm集群中,并且每台主机有一个独特的标签来区分。可以通过以下命令给主机添加标签:

docker node update --label-add <key>=<value> <node-id>

然后,当你部署服务时,可以使用 --constraint 标志来指定副本运行的主机标签。例如,如果你有两台主机,一台标签为 host=node1,另一台标签为 host=node2,你可以这样部署服务。

docker service create --replicas 2 --name my-service --constraint 'node.labels.host==node1' my-image
docker service create --replicas 2 --name my-service --constraint 'node.labels.host==node2' my-image

如果使用的yml文件来编排的服务,则修改文件内容如下:

version: '3.8'services:my-service:image: my-imagedeploy:mode: replicatedreplicas: 2placement:constraints:- "node.labels.host == node1"- "node.labels.host == node2"

在部署服务前,确保已经标记了相应的节点:

docker node update --label-add host=node1 <NODE1_ID>
docker node update --label-add host=node2 <NODE2_ID>

这样,每个副本都会被调度到一个符合指定标签的节点上。如果你有多于两台主机,并且每个副本都需要在不同的主机上运行,你可能需要为每个副本指定不同的标签约束。

请注意,如果没有足够的节点来满足所有约束条件,服务可能会创建失败或者只能运行在部分节点上。因此,集群中节点的数量和资源容量至关重要。


http://www.ppmy.cn/embedded/96330.html

相关文章

实现将docx转成PDF

最近实现了一个将docx转成PDF的功能&#xff0c;这里来记录一下实现过程 我是参考这篇文章Java将Word转换成PDF的常用用法_java_脚本之家 实现步骤基本上是按照上面文档中描述的内容&#xff0c;把大象装冰箱一共就三步 1、导入依赖 <?xml version"1.0" enco…

FreeBSD重启后无法进入多用户模式,报错failed, superblock has critical errors

FreeBSD重启后无法进入多用户模式 报错failed, superblock has critical errors 具体报错信息&#xff1a; Attempt to find boot zone recovery data. Finding an alternate superblock failed. check for only noe-critical errors in standard superblock failed, sup…

Leetcode每日刷题之611.有效三角形的个数(C++)

1. 思路解析 根据题意我们可知&#xff0c;我们需要在指定数组中找出任意三个数并判断是否可以组成一个三角形&#xff0c;即任意两数之和大于第三个数&#xff0c;任意两数之差小于第三个数&#xff0c;如果有数组元素相同的数组&#xff0c;由于取出的元素只是数值相同而实际…

微信支付流程

1. 创建订单 请求创建订单的 API 接口&#xff1a;把 订单金额、收货地址、订单中包含的商品信息 发送到服务器服务器响应的结果&#xff1a;订单编号 2.订单预支付 请求订单预支付的 API 接口&#xff1a;把步骤1得到的 订单编号 发送到服务器服务器响应的结果&#xff1a;…

【自用】Python爬虫学习(二):网页解析的三种方式(re、bs4、xpath)

Python爬虫学习&#xff08;二&#xff09; 网页解析的三种方式1.正则表达式-re解析常用表达&#xff1a;re常用函数&#xff1a;在html中的运用&#xff1a; 2.BeautifulSoup解析常用语法&#xff1a;用法举例&#xff1a; 3.xpath解析示例代码1&#xff1a;示例代码2&#xf…

Eureka原理实践

Eureka是Netflix开源的服务发现框架&#xff0c;它实现了服务的注册与发现&#xff0c;是微服务架构中不可或缺的一部分。在微服务架构中&#xff0c;服务实例会动态地注册和注销&#xff0c;因此需要一个服务注册中心来管理这些服务实例的信息&#xff0c;Eureka就承担了这个角…

[Qt][Qt 文件]详细讲解

目录 1.输入输出设备类2.文件读写类3.文件和目录信息类 1.输入输出设备类 在Qt中&#xff0c;⽂件读写的类为QFile&#xff0c;其⽗类为QFileDevice QFileDevice提供了⽂件交互操作的底层功能QFileDevice的⽗类是QIODevice&#xff0c;其⽗类为QObject QIODevice是Qt中所有I/O…

RabbitMq如何确保消息不丢失

问题&#xff1a;在生产环境中由于一些不明原因&#xff0c;导致 rabbitmq 重启&#xff0c;在 RabbitMQ 重启期间生产者消息投递失败&#xff0c;导致消息丢失&#xff0c;需要手动处理和恢复。于是&#xff0c;我们开始思考&#xff0c;如何才能进行 RabbitMQ 的消息可靠投递…