k8s用kubectl管理应用升级,服务发布与回滚,扩缩容
应用升级
Kubectl set image --help 有案例指定新版本
[root@k8s-master ~]# kubectl set image deployment/nginx nginx=nginx:1.11
升级之后他会将所有版本进行替换,用describe来查看版本
[root@k8s-master ~]# kubectl get pods
NAME READY STATUS RESTARTS AGE
busybox-5d4f595646-dzjv4 1/1 Running 0 2d
nginx-76c4c6d6d8-5w825 1/1 Running 0 2m
nginx-76c4c6d6d8-bh2sm 1/1 Running 0 2m
nginx-76c4c6d6d8-cwhw5 1/1 Running 0 1m
用describe来查看版本,看到版本已经升级为1.11版本了,另外下面还有他的输出信息
[root@k8s-master ~]# kubectl describe po/nginx-76c4c6d6d8-cwhw5
nginx:
Container ID: docker://ca046dd27d86bc10f330131be7ba5b91b14cb555c5d9677bb23f481e4e69aa67
Image: nginx:1.11
第二种修改应用版本===可以使用edit
直接进行编辑就行
[root@k8s-master ~]# kubectl edit deploy/nginx
找到image直接修改进行保存,升级之后他会将所有版本进行替换,用describe来查看版本
等启动之后查看pod重启新的镜像已经运行了
[root@k8s-master ~]# kubectl get pods
NAME READY STATUS RESTARTS AGE
busybox-5d4f595646-dzjv4 1/1 Running 0 2d
nginx-7454cd89d8-fpncj 1/1 Running 0 5m
nginx-7454cd89d8-gdz8c 1/1 Running 0 4m
nginx-7454cd89d8-tlngj 1/1 Running 0 5m
用describe查看Pod镜像信息
[root@k8s-master ~]# kubectl describe po/nginx-7454cd89d8-tlngj
nginx:
Container ID: docker://6768df2391defe44097e3ce2a857529ec614d49962181c1cf541c1bbc6dbce08
Image: nginx:1.15
用node端直接访问查看版本
[root@k8s-node1 ~]# curl -I 10.10.10.173:88
HTTP/1.1 200 OK
Server: nginx/1.15.12
Date: Mon, 08 Jul 2019 04:23:42 GMT
查看版本升级信息
[root@k8s-master ~]# kubectl rollout history deploy/nginx
deployments "nginx"
REVISION CHANGE-CAUSE
1 <none>
2 <none>
3 <none>
记录版本信息状态,便于回滚
[root@k8s-master ~]# kubectl set image deployment/nginx nginx=nginx:1.16 --record
[root@k8s-master ~]# kubectl rollout history deploy/nginx
deployments "nginx"
REVISION CHANGE-CAUSE
1 <none>
2 <none>
3 <none>
4 kubectl set image deployment/nginx nginx=nginx:1.16 --record=true
进行回滚用rollout undo,默认恢复到上一个版本也就是1.15
[root@k8s-master ~]# kubectl rollout undo deploy/nginx
默认少一个3,也就是回到上次第三次版本了
[root@k8s-master ~]# kubectl rollout history deploy/nginx
deployments "nginx"
REVISION CHANGE-CAUSE
1 <none>
2 <none>
4 kubectl set image deployment/nginx nginx=nginx:1.16 --record=true
5 <none>
[root@k8s-master ~]# kubectl describe po/nginx-7454cd89d8-txjpm
Containers:
nginx:
Container ID: docker://f17b88c301d61b8c75a46cba84d97c285f5d61886c081b3cfc9c0668e5cbf4e3
Image: nginx:1.15
业务量突然增加,我们需要增加副本
[root@k8s-master ~]# kubectl scale deploy/nginx --replicas=10
deployment "nginx" scaled
[root@k8s-master ~]# kubectl get pod
NAME READY STATUS RESTARTS AGE
busybox-5d4f595646-dzjv4 1/1 Running 0 2d
nginx-7454cd89d8-4cct8 1/1 Running 0 19s
nginx-7454cd89d8-75tvg 1/1 Running 0 7m
nginx-7454cd89d8-7v5qp 1/1 Running 0 1m
nginx-7454cd89d8-dtsgq 1/1 Running 0 19s
nginx-7454cd89d8-hjcpw 1/1 Running 0 7m
nginx-7454cd89d8-mhhww 1/1 Running 0 19s
nginx-7454cd89d8-txjpm 1/1 Running 0 7m
nginx-7454cd89d8-vkmjn 1/1 Running 0 19s
nginx-7454cd89d8-z8dbn 1/1 Running 0 19s
nginx-7454cd89d8-zn8pm 1/1 Running 0 1m
业务量下降我们进行缩容
[root@k8s-master ~]# kubectl scale deploy/nginx --replicas=5
[root@k8s-master ~]# kubectl get pod
NAME READY STATUS RESTARTS AGE
busybox-5d4f595646-dzjv4 1/1 Running 0 2d
nginx-7454cd89d8-75tvg 1/1 Running 0 8m
nginx-7454cd89d8-7v5qp 1/1 Running 0 3m
nginx-7454cd89d8-hjcpw 1/1 Running 0 8m
nginx-7454cd89d8-txjpm 1/1 Running 0 8m
nginx-7454cd89d8-zn8pm 1/1 Running 0 3m
要是不需要这些资源或者换项目了
直接用delete=======删除deploy还有service
[root@k8s-master ~]# kubectl delete deploy/nginx
deployment "nginx" deleted
[root@k8s-master ~]# kubectl delete svc/nginx-service
查看资源已经删除
[root@k8s-master ~]# kubectl get all
k8s用kubectl管理应用升级,服务发布与回滚,扩缩容的更多相关文章
- k8s 集群管理和微服务 适合做啥
k8s 集群管理和微服务 适合做啥 都知道k8s是集群 适合微服务 有很多教程 但你可以先了解他能干啥 traefix 是负载均衡工具 k8s 适合部署无状态依赖的微服务 可以按需求开启多个微服务 管 ...
- 通过Dapr实现一个简单的基于.net的微服务电商系统(十一)——一步一步教你如何撸Dapr之自动扩/缩容
上一篇我们讲到了dapr提供的bindings,通过绑定可以让我们的程序轻装上阵,在极端情况下几乎不需要集成任何sdk,仅需要通过httpclient+text.json即可完成对外部组件的调用,这样 ...
- Docker Swarm 服务版本更新与回滚
Docker Swarm 服务版本更新 环境: 系统:Centos 7.4 x64 应用版本:Docker 18.09.0 管理节点:192.168.1.79 工作节点:192.168.1.78 工作 ...
- ansible实现发布、回滚功能
ansible的两篇博客,本来是打算合二为一的,发现只用一篇写,嗯,好鬼长.... 一向秉承简单为美的我于是忍痛割爱,一分为二了 ansible实现升级发布.回滚功能 1.应用场景 在实际生产环境中, ...
- 构建Docker平台【第四篇】创建服务及扩缩容等操作
第一步:创建服务 1. 配置 nginx 的 yaml 文件 apiVersion: extensions/v1beta1 kind: Deployment metadata: name: my-ng ...
- 2、jenkins+svn自动发布和回滚
Jenkins配置回滚思路: 目前只能实现使用salt来管控配置文件的管控,配置文件的版本回滚需要后续定制化开发,或者进行格外其他的管理操作.后续实现 以下配置可以为每个项目备份构建文件到本地指定路径 ...
- Jenkins实用发布与回滚PHP项目生产实践
目录 1.概述 2.项目实践 2.1.环境说明 2.2.Jenkins配置 2.2.1.修改Jenkins的运行用户 2.2.2.配置Jenkins用户和Gitlab的ssh-key 2.2.3.Je ...
- Jenkins 搭建企业实战案例 (发布与回滚)
让我们的代码部署变得easy,不再难,Jenkins是一个可扩展的持续集成引擎,是一个开源软件项目,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能.Jenkins非常易于安装和配置,简单易用 ...
- Docker Swarm(七)Scale 扩(缩)容服务
扩(缩)容服务 扩容服务 Service还提供了复制(类似kubernetes里的副本)功能.可以通过 docker service scale 命令来设置服务中容器的副本数: docker serv ...
随机推荐
- Happens-Before原则到底规定了什么
Happens-Before 规则 如何理解 Happens-Before 呢?如果望文生义(很多网文也都爱按字面意思翻译成"先行发生"),那就南辕北辙了,Happens-Befo ...
- Hadoop核心-HDFS
上一篇我们熟悉了hadoop,本篇讲解一下hadoop第一个核心HDFS. 一.概述 HDFS是一个分布式文件存储系统,以流式数据访问模式存储超大文件,将数据分块存储到一个商业硬件集群内的不同机器上, ...
- 深度学习炼丹术 —— Taoye不讲码德,又水文了,居然写感知器这么简单的内容
手撕机器学习系列文章就暂时更新到此吧,目前已经完成了支持向量机SVM.决策树.KNN.贝叶斯.线性回归.Logistic回归,其他算法还请允许Taoye在这里先赊个账,后期有机会有时间再给大家补上. ...
- 程序综合设计实践 :QT实现计算器
程序综合设计实践 :用QT实现简易计算器及贷款计算 1,项目概述 该项目目标是设计开发一个支持连续计算的包括括号( ),求余%四则运算+ - * /的计算器 Calculator 以及贷款计算功能 M ...
- shiro 拦截时序图
shiro 集成 web 1.第一个过滤器-AbstractShiroFilter subject 是后续动作的主体. 首先构造 subject: WebSubject DefaultSecurity ...
- 读取xlsx文件的内容输入到xls文件中
package com.cn.peitest.excel; import java.io.File; import java.io.FileInputStream; import java.io.Fi ...
- 输入xls格式 输出 xls
package com.cn.peitest.excel.word; import java.io.File; import java.io.FileInputStream; import java. ...
- C#——线程总结
#线程详解 1. Thread基础之从 WinDbg 角度理解你必须知道的时间和空间上的开销 一:空间上的开销 1.thread本身来说就是操作系统的概念... <1> thread的内核 ...
- 面试常问:Mybatis使用了哪些设计模式?
前言 虽然我们都知道有26个设计模式,但是大多停留在概念层面,真实开发中很少遇到,Mybatis源码中使用了大量的设计模式,阅读源码并观察设计模式在其中的应用,能够更深入的理解设计模式. Mybati ...
- [leetcode]29. Divide Two Integers不用除法实现除法
思路是不断将被除数分为两部分,每次分的一部分都是尽量大的除数的倍数,然后最后的商就是倍数加上剩下的部分再分,知道不够大. 递归实现 剩下的难点就是,正负号(判断商正负后将两个数都取绝对值),数太大(将 ...