在前面的实验中,我们部署了多个副本的服务,本节将讨论如何滚动更新每一个副本。
 
滚动更新降低了应用更新的风险,如果某个副本更新失败,整个更新将暂停,其他副本则可以继续提供服务。
同时在更新的过程中,总是有副本在运行的,因此也保证了业务的连续性。
 
下面我们进行一个实验,将一个 3 副本的httpd Service,我们将 httpd镜像的版本进行升级
 
httpd:2.4.35  升级到 httpd:2.4.37
 
root@host03:~# docker service create --name httpd_2435 --replicas 3 httpd:2.4.35    #    创建Service 镜像 httpd:2.4.35,副本数3
8ppmoni91g7u22z4f4if61ro7
overall progress: 3 out of 3 tasks
1/3: running   
2/3: running   
3/3: running   
verify: Service converged 
root@host03:~# docker service update --image httpd:2.4.37 httpd_2435    #    更新Service 镜像到 httpd:2.4.37
httpd_2435
overall progress: 3 out of 3 tasks
1/3: running   
2/3: running   
3/3: running   
verify: Service converged
 
root@host03:~# docker service ps httpd_2435    #    更新前Service各副本状态
ID                  NAME                IMAGE               NODE                DESIRED ST          PORTS
hkb5vb4ocqu6        httpd_2435.1        httpd:2.4.35        host02              Running             
3v4vikx98pgm        httpd_2435.2        httpd:2.4.35        host01              Running             
d58skm47doqf        httpd_2435.3        httpd:2.4.35        host02              Running             
root@host03:~# docker service ps httpd_2435    #    更新副本2过程中
ID                  NAME                IMAGE               NODE                DESIRED ST          PORTS
hkb5vb4ocqu6        httpd_2435.1        httpd:2.4.35        host02              Running                  
ys34lst9obij        httpd_2435.2        httpd:2.4.37        host01              Ready                    
3v4vikx98pgm         \_ httpd_2435.2    httpd:2.4.35        host01              Shutdown                 
d58skm47doqf        httpd_2435.3        httpd:2.4.35        host02              Running                  
root@host03:~# docker service ps httpd_2435    #    更新副本2完毕
ID                  NAME                IMAGE               NODE                DESIRED ST          PORTS
hkb5vb4ocqu6        httpd_2435.1        httpd:2.4.35        host02              Running             
ys34lst9obij        httpd_2435.2        httpd:2.4.37        host01              Running             
3v4vikx98pgm         \_ httpd_2435.2    httpd:2.4.35        host01              Shutdown            
d58skm47doqf        httpd_2435.3        httpd:2.4.35        host02              Running             
root@host03:~# docker service ps httpd_2435    #    更新副本3完毕
ID                  NAME                IMAGE               NODE                DESIRED ST               PORTS
hkb5vb4ocqu6        httpd_2435.1        httpd:2.4.35        host02              Running                  
ys34lst9obij        httpd_2435.2        httpd:2.4.37        host01              Running                  
3v4vikx98pgm         \_ httpd_2435.2    httpd:2.4.35        host01              Shutdown                 
pujxt7yrum1d        httpd_2435.3        httpd:2.4.37        host01              Running                  
d58skm47doqf         \_ httpd_2435.3    httpd:2.4.35        host02              Shutdown                 
root@host03:~# docker service ps httpd_2435    #    更新副本1完毕
ID                  NAME                IMAGE               NODE                DESIRED ST               PORTS
hguoom4ihf8t        httpd_2435.1        httpd:2.4.37        host02              Running                  
hkb5vb4ocqu6         \_ httpd_2435.1    httpd:2.4.35        host02              Shutdown                 
ys34lst9obij        httpd_2435.2        httpd:2.4.37        host01              Running                  
3v4vikx98pgm         \_ httpd_2435.2    httpd:2.4.35        host01              Shutdown                 
pujxt7yrum1d        httpd_2435.3        httpd:2.4.37        host01              Running                  
d58skm47doqf         \_ httpd_2435.3    httpd:2.4.35        host02              Shutdown                 
 
root@host03:~# docker service update --rollback httpd_2435    #    回滚到之前的版本
httpd_2435
rollback: manually requested rollback
overall progress: rolling back update: 3 out of 3 tasks
1/3: running   
2/3: running   
3/3: running   
verify: Service converged
 
root@host03:~# docker service ps httpd_2435    #    回滚到之前的版本后,新开了一个 httpd:2.4.25,而不是使用之前的 httpd:2.4.35
ID                  NAME                IMAGE               NODE                DESIRED STATE       CURRENT STATE                ERROR               PORTS
py7dm0500o2z        httpd_2435.1        httpd:2.4.35        host02              Running             Running 19 seconds ago                           
hguoom4ihf8t         \_ httpd_2435.1    httpd:2.4.37        host02              Shutdown            Shutdown 20 seconds ago                          
hkb5vb4ocqu6         \_ httpd_2435.1    httpd:2.4.35        host02              Shutdown            Shutdown about an hour ago                       
rdvhf3z4zh7r        httpd_2435.2        httpd:2.4.35        host01              Running             Running 17 seconds ago                           
ys34lst9obij         \_ httpd_2435.2    httpd:2.4.37        host01              Shutdown            Shutdown 18 seconds ago                          
3v4vikx98pgm         \_ httpd_2435.2    httpd:2.4.35        host01              Shutdown            Shutdown about an hour ago                       
xed1n7sy7td8        httpd_2435.3        httpd:2.4.35        host01              Running             Running 22 seconds ago                           
pujxt7yrum1d         \_ httpd_2435.3    httpd:2.4.37        host01              Shutdown            Shutdown 23 seconds ago                          
d58skm47doqf         \_ httpd_2435.3    httpd:2.4.35        host02              Shutdown            Shutdown about an hour ago     
 
 
默认配置下,Swarm一次只能更新一个副本,并且两个副本之间没有等待时间,我们可以通过 -- update-parallelism 设置并行更新的副本数目,通过--update-delay 指定滚动更新的时间间隔。
 
下面的例子中,我们有20个副本,更新并发数 4 ,更新延时 10s
 
root@host03:~# docker service update --image httpd:2.2 --update-parallelism 4 --update-delay 10s httpd_2435
 
ps:弹性伸缩时,即增减副本数并不受此限制,会以最快的速度完成伸缩
 
 
 
 
 
 
 

102、如何滚动更新 Service (Swarm09)的更多相关文章

  1. 如何滚动更新 Service?- 每天5分钟玩转 Docker 容器技术(102)

    在前面的实验中,我们部署了多个副本的服务,本节将讨论如何滚动更新每一个副本. 滚动更新降低了应用更新的风险,如果某个副本更新失败,整个更新将暂停,其他副本则可以继续提供服务.同时,在更新的过程中,总是 ...

  2. Kubernetes集群中Service的滚动更新

    Kubernetes集群中Service的滚动更新 二月 9, 2017 0 条评论 在移动互联网时代,消费者的消费行为已经“全天候化”,为此,商家的业务系统也要保持7×24小时不间断地提供服务以满足 ...

  3. 入门 - k8s滚动更新部署中的镜像版本 (七)

    目标 使用 kubectl 执行 Rolling Update(滚动更新) 更新应用程序 用户期望应用程序始终可用,为此开发者/运维者在更新应用程序时要分多次完成.在 Kubernetes 中,这是通 ...

  4. docker swarm集群搭建以及使用滚动更新

    基础环境,三台虚拟机 172.17.3.70 172.17.3.71 172.17.3.72 系统配置:centos 7,关闭selinux 需要优化的基础配置: [root@sw1 ~]# vim ...

  5. 详细聊聊k8s deployment的滚动更新(二)

    一.知识准备 ● 本文详细探索deployment在滚动更新时候的行为 ● 相关的参数介绍:   livenessProbe:存活性探测.判断pod是否已经停止   readinessProbe:就绪 ...

  6. Kubernetes Deloyment实现滚动更新

    目录 滚动更新简介 使用kubectl rolling-update更新RC Deployment的rolling-update 滚动更新简介 当kubernetes集群中的某个服务需要升级时,传统的 ...

  7. docker swarm实现java项目的发布/滚动更新/回滚/镜像管理

    使用docker swarm滚动更新java项目,部署集群,这一切的前提是使用Jenkins+maven进行项目打包,分发等功能 具体可以参考我的另外三篇文章 https://www.cnblogs. ...

  8. kubernetes滚动更新

    系列目录 简介 当kubernetes集群中的某个服务需要升级时,传统的做法是,先将要更新的服务下线,业务停止后再更新版本和配置,然后重新启动并提供服务.如果业务集群规模较大时,这个工作就变成了一个挑 ...

  9. deployment控制pod进行滚动更新以及回滚

    更新pod镜像两种方式: 方式一:kubectl set image deployment/${deployment name} ${container name}=${image} 例: kubec ...

随机推荐

  1. Nginx-rtmp点播之complex handshake

    1. 点播的配置 假设配置文件 nginx.conf 中对 rtmp 配置如下: # 创建的子进程数 worker_processes 1; #error_log logs/error.log; er ...

  2. How to intercept any postback in a page? - ASP.NET

    How to intercept any postback in a page? - ASP.NET There's a couple of things you can do to intercep ...

  3. C# 中使用RegisterShellHookWindow Hook窗体创建

    前言:最近在写一个桌面程序时需要全局HOOK 窗体的创建,但是在.net中SetWindowsHookEx()只可实现键盘鼠标的全局钩子,其余的全局钩子都需要使用DLL.难道就没有解决办法了么?经过长 ...

  4. RzPageControl(pagecontrol)实现多标签的动态添加,切换,关闭

    https://blog.csdn.net/pdw2009/article/details/76157651 使用RzPageControl来实现多标签页使用菜单来打开标签页,通过标签页的captio ...

  5. 排查python内存泄露中几个工具的使用

    本文主要介绍3个工具:pdb,objgraph,以及pympler. 1.pdb pdb是专门用于python代码调试,模仿gdb. 使用pdb可以查看堆栈,打印变量等. 这里介绍的是命令行下的pdb ...

  6. centos的KVM初级安装

    什么是KVM虚拟化技术?KVM(Kernel-based Virtual Machine),主流虚拟化技术之一,集成与Linux2.6之后版本中,通过linux内核提供任务调度及管理.kvm,在实现虚 ...

  7. Xman冬令营writeup

    做题一时爽,期末火葬场,一晚上水了三题,跪求期末不挂,老老实实去复习.祝各位表哥冬令营玩的开心. 中二的成长之路 很容易发现图片本身就是个压缩包,里面还有个图片,但是加密了所以需要我们求出压缩包的密码 ...

  8. 阶段3 3.SpringMVC·_03.SpringMVC常用注解_4 HiddentHttpMethodFilter过滤器

    此文只做了解!! 过滤器 ,了解即可 请求设置为post的方式 换成put的方式 浏览器模拟发送PUT请求 ,不大好模拟.顾虑器可以帮助我们发送不同的请求 过滤器会拿到这个请求 详情可以看文档,此处不 ...

  9. 工具类 分页工具类PageParamBean

    自己编写的分页工具类,根据不同的数据库类型,生成对应的分页sql信息,分享给大家,希望大家共勉,工具类有些地方,大家可能不需要,请根绝自己的需要进行修改使用,核心逻辑都在,如果大家觉得有什么不妥,欢迎 ...

  10. centos 7安装python3及相关模块

    一.python3安装 1.cd /usr/bin 2.mv python python.bak 3.https://www.python.org/ftp/python/网站选择合适的版本 4.wge ...