上一节我们讨论了 Service部署的两种模式,global mode 和 replicated mode 。无论global mode 还是replicated mode ,副本运行在哪些节点都是由Swarm决定的。
那么作为用户我们没有可能精细控制 Service运行的位置呢? 答案是:能 , 使用label
过程分两步:
1、为每个node 定义label
2、设置Service运行在指定label的node上
label 可以灵活的描述node的属性,其形式是 key = value ,用户可以任意指定,例如将 swarm-worker1 作为测试环境,为其添加label env=test
host01标记为测试环境,host02标记为线上环境
root@host03:~# docker node update --label-add env=test host01 # 将host01标记为测试环境
host01
root@host03:~# docker node inspect host01 --pretty
ID: hvt2ez9e7zvqm2hz8nix1eke7
Labels:
- env=test
Hostname: host01
Joined at: 2019-05-14 03:19:30.200301075 +0000 utc
Status:
State: Ready
Availability: Active
Address: 10.12.31.211
root@host03:~# docker node update --label-add env=prod host02 # 将host02标记为线上环境
host02
root@host03:~# docker node inspect host02 --pretty
ID: asn5ufnogzkyqigk4mizatoer
Labels:
- env=prod
Hostname: host02
Joined at: 2019-05-14 03:19:34.507855133 +0000 utc
Status:
State: Ready
Availability: Active
Address: 10.12.31.212
在测试环境创建Service my_web ,副本数 3
root@host03:~# docker service create --name my_web --replicas 3 --constraint node.labels.env==test --publish 80:80 httpd
addp6i8pm0msmamq6a4oc94py
overall progress: 3 out of 3 tasks
1/3: running [==================================================>]
2/3: running [==================================================>]
3/3: running [==================================================>]
verify: Service converged
root@host03:~# docker service ps my_web # 确认所有的副本都在测试环境的node上
ID NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR PORTS
63mta4uzj5kh my_web.1 httpd:latest host01 Running Running 11 seconds ago
svynuplsq5l9 my_web.2 httpd:latest host01 Running Running 11 seconds ago
y8ion2zxr2fb my_web.3 httpd:latest host01 Running Running 11 seconds ago
root@host03:~# docker service inspect my_web --pretty
ID: addp6i8pm0msmamq6a4oc94py
Name: my_web
Service Mode: Replicated
Replicas: 3
Placement:
Constraints: [node.labels.env==test]
将 my_web 的Service 从测试环境迁移到线上环境
root@host03:~# docker service update --constraint-rm node.labels.env==test my_web # 删除Service 测试环境的标签
my_web
overall progress: 3 out of 3 tasks
1/3: running [==================================================>]
2/3: running [==================================================>]
3/3: running [==================================================>]
verify: Service converged
root@host03:~# docker service ps my_web
ID NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR PORTS
63mta4uzj5kh my_web.1 httpd:latest host01 Running Running 4 minutes ago
svynuplsq5l9 my_web.2 httpd:latest host01 Running Running 4 minutes ago
y8ion2zxr2fb my_web.3 httpd:latest host01 Running Running 4 minutes ago
root@host03:~# docker service update --constraint-add node.labels.env==prod my_web # 添加Service 线上环境的标签
my_web
overall progress: 3 out of 3 tasks
1/3: running [==================================================>]
2/3: running [==================================================>]
3/3: running [==================================================>]
verify: Service converged
root@host03:~# docker service ps my_web
ID NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR PORTS
mj39f4gddt7g my_web.1 httpd:latest host02 Running Running 17 seconds ago
63mta4uzj5kh \_ my_web.1 httpd:latest host01 Shutdown Shutdown 18 seconds ago
r82s4x7t8cft my_web.2 httpd:latest host02 Running Running 12 seconds ago
svynuplsq5l9 \_ my_web.2 httpd:latest host01 Shutdown Shutdown 13 seconds ago
nxu3gvglcn5y my_web.3 httpd:latest host02 Running Running 8 seconds ago
y8ion2zxr2fb \_ my_web.3 httpd:latest host01 Shutdown Shutdown 9 seconds ago
label 与 global mode 组合,只收集线上环境的日志
root@host03:~# docker service create --mode global --constraint node.labels.env==prod --name monitor busybox sleep 99999
vbo0n6hgrr8qehw1kql3znk4y
overall progress: 1 out of 1 tasks
asn5ufnogzky: running [==================================================>]
verify: Service converged
root@host03:~# docker service ps monitor
ID NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR PORTS
bek7a8mt387i monitor.asn5ufnogzkyqigk4mizatoer busybox:latest host02 Running Running 24 seconds ago
- 用 Label 控制 Service 的位置 - 每天5分钟玩转 Docker 容器技术(106)
上一节我们讨论了 Service 部署的两种模式:global mode 和 replicated mode.无论采用 global mode 还是 replicated mode,副本运行在哪些节点 ...
- 用 label 控制 Pod 的位置 - 每天5分钟玩转 Docker 容器技术(128)
默认配置下,Scheduler 会将 Pod 调度到所有可用的 Node.不过有些情况我们希望将 Pod 部署到指定的 Node,比如将有大量磁盘 I/O 的 Pod 部署到配置了 SSD 的 Nod ...
- centos7下kubernetes(9。kubernetes中用label控制pod得位置)
Kubernetes通过label实现将pod运行在指定得node上. 默认配置下,Schesuler将pod调度到所有可用得node,有时候我们希望将pod部署到指定得node,比如将有大量磁盘I/ ...
- 用 label 控制 Pod 的位置
默认配置下,Scheduler 会将 Pod 调度到所有可用的 Node.不过有些情况我们希望将 Pod 部署到指定的 Node,比如将有大量磁盘 I/O 的 Pod 部署到配置了 SSD 的 Nod ...
- LaTeX技巧96:LaTeX 图片控制命令,位置控制
LaTeX技巧96:LaTeX 图片控制命令,位置控制 2012-04-05 17:25:44 zd0303 阅读数 28512更多 分类专栏: Latex LaTeX 控制图片的位置,就是加感叹 ...
- “Win10 UAP 开发系列”之 在MVVM模式中控制ListView滚动位置
这个扩展属性从WP8.1就开始用了,主要是为了解决MVVM模式中无法直接控制ListView滚动位置的问题.比如在VM中刷新了数据,需要将View中的ListView滚动到顶部,ListView只有一 ...
- textfield控制光标开始位置
// UIView *paddingView1 = [[UIView alloc] initWithFrame:CGRectMake(0, 64, self.view.frame.size.wi ...
- Demo 示例控制输入光标位置
<!DOCTYPE html> <html> <head> <meta charset=utf-8 /> <meta name="aut ...
- LBS(Location Based Service)(基于位置的服务)
LBS(Location Based Service)(基于位置的服务) Android 中定位方式基本可以分为两种:GPS定位,网络定位. GPS定位的工作原理是基于手机内置的GPS硬件直接和卫星进 ...
随机推荐
- 服务安全-IAM:百科
ylbtech-服务安全-IAM:百科 IAM(身份识别与访问管理(简称大4A)) IAM(Identity and Access Management 的缩写),即“身份识别与访问管理”,具有单点登 ...
- 网络通信框架之volley
介绍 我们平时在开发Android应用的时候不可避免地都需要用到网络技术,而多数情况下应用程序都会使用HTTP协议来发送和接收网络数据.Android系统中主要提供了两种方式来进行HTTP通信,Htt ...
- TcpSendRcv方法笔记1
if (ns.DataAvailable) return ns.ReadByte(); ns.DataAvailable:获取一个值,该值指示在要读取的 NetworkStream 上是否有可用的数据 ...
- spring mvc路径匹配原则
Ant path 匹配原则 在Spring MVC中经常要用到拦截器,在配置需要要拦截的路径时经常用到<mvc:mapping/>子标签,其有一个path属性,它就是用来指定需要拦截的路径 ...
- zabbix客户端监控
1.安装zabbix客户端软件: yum install -y zabbix20-agent2.修改配置文件vim /etc/zabbix_agentd.conf修改如下: (1)更改Server,S ...
- 阶段3 3.SpringMVC·_04.SpringMVC返回值类型及响应数据类型_6 响应json数据之过滤静态资源
先搭建环境 webapp目录下创建js的文件夹.然后里面引入jquery.min.js这个文件. 页面引入这个js文件 先alert弹窗做测试 服务器重新部署 点击ajax的按钮 并没有起作用 我们在 ...
- SQL学习(七)试图
试图是基于SQL语句的结果集的可视化表. 1.创建试图 create view 试图名 as select 语句 如: create view ticketresult as select * fro ...
- 关于Linux下的连接文件学习总结
1.连接文件区分为两种,一种类似windows下快捷方式,使用户能够快速连接到目标文件或目录. 另一种则通过文件系统中的inode连接来产生新文件名,而不是产生新文件. 两种方式分别称为符号/硬连接. ...
- 2019 1月 第三次java基础有感
毕业半年了,一直在游戏公司做游戏服务器开发,java语言. 工作中,写着写着代码,接触java多了,有时候就会发现自己的java基础会不够用.以前实习的时候也体会到一次,然后过了一遍基础.现在正式工作 ...
- Laravel底层原理系列
Laravel 从学徒到工匠精校版 地址:https://laravelacademy.org/laravel-from-appreciate-to-artisan Advanced Applicat ...