Docker教程总结九:(swarm节点标签与服务约束即强制指定容器节点)
多节点 Swarm 集群下,可能节点的配置不同(比如 CPU、内存等),部署着不同类型的服务(比如 Web服务、Job服务等),当这些服务以 Service 或者 Stack 的形式部署到集群,默认情况下会随机分配到各个节点。不同类型的服务对服务器需求的资源是不同的,为了更合理的利用服务器资源,我们可能希望某些服务能够部署到指定的服务器上。另外一种场景,Swarm 集群中的节点跨机房,为了内部服务间通信更快,我们可能希望关联比较密切的服务能够部署到同一机房的节点上。那么,如何做到呢?
很简单,先给节点添加标签,然后服务发布时添加限制条件即可!
Node Label 管理
示例集群信息:
1
2
3
4
5
|
docker@node1:~$ docker node ls
ID HOSTNAME STATUS AVAILABILITY MANAGER STATUS ENGINE VERSION
axr4zun8u1es8ytizjpt3zlnw * node1 Ready Active Leader 18.03.0–ce
vdip2js7tfflxv0smj6wdw0bv node2 Ready Active 18.03.0–ce
vi17ametnwd58297z6nlcl2o0 node3 Ready Active 18.03.0–ce
|
添加标签
1
|
docker node update —label–add role=web node1
|
查看标签
1
|
docker node inspect node1
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
[
{
“ID”: “axr4zun8u1es8ytizjpt3zlnw”,
“Version”: {
“Index”: 476
},
“CreatedAt”: “2018-07-19T03:50:02.734603631Z”,
“UpdatedAt”: “2018-07-30T06:37:04.465194614Z”,
“Spec”: {
“Labels”: {
“role”: “web” # 人工添加的标签
},
“Role”: “manager”,
“Availability”: “active”
}
# 省略
}
]
|
删除标签
1
|
docker node update —label–rm role node1
|
服务部署条件约束
Service 方式
1
2
3
4
|
docker service create
—name nginx_2
—constraint ‘node.labels.role == web’
nginx
|
Stack 方式
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
version: ‘3.6’
services:
mycat:
image: nginx
ports:
– target: 8080
published: 8080
protocol: tcp
mode: ingress
deploy:
mode: global
placement:
constraints: # 添加条件约束
– node.labels.role==web
restart_policy:
condition: on–failure
max_attempts: 3
|
constraints
为数组,填写多个约束时,它们之间的关系是 AND
。
条件约束补充
constraints
可以匹配 node
标签和 engine
标签,engine.labels
适用于 Docker Engine 标签,如操作系统,驱动程序等,node.labels
适用于上述人为添加到节点的。
node | attribute matches | example |
---|---|---|
node.id | Node ID | node.id==2ivku8v2gvtg4 |
node.hostname | Node hostname | node.hostname!=node-2 |
node.role | Node role | node.role==manager |
node.labels | user defined node labels | node.labels.security==high |
engine.labels | Docker Engine’s labels | engine.labels.operatingsystem==ubuntu 14.04 |
转载备份:https://www.jianshu.com/p/2a11a40a9573
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 精力有限,不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别
丞旭猿论坛
暂无评论内容