k8s学习笔记(3)- kubectl高可用部署,扩容,升级,回滚springboot应用
前言:上一篇通过rancher管理k8s,部署服务应用扩容,高可用,本篇介绍kubectl命令行部署高可用集群节点,测试升级、扩容等
1、测试环境:3节点k3s,使用其中2节点(ubuntunode1与ubuntunode2),node3暂不用
输入命令,查看节点状况

2、进入任意节点,使用kubectl命令行进行服务部署操作,我们这里用node1节点
新建一个.yaml文件,用于部署2个负载的应用,文件名称:springbootapp-2nodes.yaml

文件内容如下,kind节点使用Deployment类型:

文本如下:
apiVersion: apps/v1
kind: Deployment
metadata:
name: springbootapp-dep
labels:
app: springbootapp
spec:
replicas: 2
selector:
matchLabels:
app: springbootapp
template:
metadata:
labels:
app: springbootapp
spec:
containers:
- name: springbootapp
image: xjk27400861/springbootapp:42
ports:
- containerPort: 8080
新建一个命名空间,用于部署集群应用
命令如下:
sudo kubectl create namespace springboot2node

输入命令,创建2节点副本应用,-n 指定命名空间
命令如下:
sudo kubectl create -f springbootapp-2nodes.yaml -n springboot2node

也可以在.yaml文件中指定命名空间:

输入命令,查看pod节点运行状态
命令如下:
sudo kubectl get pods -n springboot2node

输入命令,查看副本集情况
命令如下:
sudo kubectl get rs -n springboot2node

输入命令,创建一个svc的service,暴露集群
命令如下:
sudo kubectl apply -f springbootapp-2node-svc.yaml

springbootapp-2node-svc.yaml文件内容如下:
apiVersion: v1
kind: Service
metadata:
name: springbootapp-2node-svc
namespace: springboot2node
labels:
app: springbootapp-2node-svc
spec:
type: NodePort
ports:
- port: 8080
nodePort: 30001
selector:
app: springbootapp

通过任意节点ip+端口:30001+路由即可访问应用,我这是:http://192.168.231.133:30001/hello 或 http://192.168.231.134:30001/hello

3、k8s扩容
修改配置文件springbootapp-2nodes.yaml,2节点改为3节点

输入命令,重新部署,查看副本集变为3个
sudo kubectl apply -f springbootapp-2nodes.yaml --record=true

查看pod数量,也为3个

4、k8s自愈性
删除2个pod,模拟服务器宕机状况
sudo kubectl delete pod springbootapp-dep-67656f6dc9-cncb6 springbootapp-dep-67656f6dc9-pp47x -n springboot2node

重新查看pod状况,发现又重新构建了2个新的pod,保证负载还是3台
sudo kubectl get pods -n springboot2node

5、k8s升级
修改代码,区分版本,重新构建镜像推到仓库

新镜像tag:43

修改部署文件:springbootapp-2nodes.yaml,镜像版本改为43

输入命令,重新部署应用,参数--record=true让 Kubernetes 把这行命令记到发布历史中方便后面查看
sudo kubectl apply -f springbootapp-2nodes.yaml --record=true

ContainerCreating状态的表示新版本的容器正在启动,Running的是新版本的已经运行起来了,Terminating的这个是老版本正在停止
过了一段时间,发现3个节点已经创建完成

访问应用,即可看见新版本已发布完成

6、k8s回滚应用
输入命令,查看发布历史
sudo kubectl rollout history deployment springbootapp-dep -n springboot2node

可以看到有2个版本,我们回滚到版本1的状态
sudo kubectl rollout undo deployment springbootapp-dep --to-revision=1 -n springboot2node
查看回滚状态,成功
sudo kubectl rollout status deployment springbootapp-dep -n springboot2node

访问应用,即可看见应用已回滚到老版本

7、rancher2.x对springboot2node进行迁移,迁移到default项目下,便于rancher管理

点击右侧下拉菜单,移动


命名空间已转移到项目default中

以后可以通过rancher操作应用扩容缩容回滚等,会相当方便

k8s学习笔记(3)- kubectl高可用部署,扩容,升级,回滚springboot应用的更多相关文章
- Kafka学习笔记-如何保证高可用
一.术语 1.1 Broker Kafka 集群包含一个或多个服务器,服务器节点称为broker. broker存储topic的数据. 如果某topic有N个partition,集群有N个broker ...
- k8s学习笔记(1)- 简单部署springboot应用
前言:k8s全称kubernetes,k8s是为容器服务而生的一个可移植容器的编排管理工具,越来越多的公司正在拥抱k8s,并且当前k8s已经主导了云业务流程,关于更多的k8s知识,可自行学习 1.k8 ...
- redis 学习笔记(4)-HA高可用方案Sentinel配置
上一节中介绍了master-slave模式,在最小配置:master.slave各一个节点的情况下,不管是master还是slave down掉一个,“完整的”读/写功能都将受影响,这在生产环境中显然 ...
- SpringCloud学习笔记(6)——Eureka高可用
参考Spring Cloud官方文档第12章12.3.12.5.12.6小节 12.3 High Availability, Zones and Regions 默认情况下,每一个Eureka服务器同 ...
- Spring学习笔记——Spring事务仅仅对执行时异常回滚
我们在使用Spring时候一般都知道事务在遇到异常的时候会回滚.岂不知Spring的事务默认仅仅有在发生执行时异常即:RunTimeException时才会发生事务,假设一个方法抛出Exception ...
- Rancher Server HA的高可用部署实验-学习笔记
转载于https://blog.csdn.net/csdn_duomaomao/article/details/78771731 Rancher Server HA的高可用部署实验-学习笔记 一.机器 ...
- 【K8s学习笔记】K8s是如何部署应用的?
本文内容 本文致力于介绍K8s一些基础概念与串联部署应用的主体流程,使用Minikube实操 基础架构概念回顾 温故而知新,上一节[K8S学习笔记]初识K8S 及架构组件 我们学习了K8s的发展历史. ...
- kubernetes 1.15.1 高可用部署 -- 从零开始
这是一本书!!! 一本写我在容器生态圈的所学!!! 重点先知: 1. centos 7.6安装优化 2. k8s 1.15.1 高可用部署 3. 网络插件calico 4. dashboard 插件 ...
- kubernetes1.7.6 ha高可用部署
写在前面: 1. 该文章部署方式为二进制部署. 2. 版本信息 k8s 1.7.6,etcd 3.2.9 3. 高可用部分 etcd做高可用集群.kube-apiserver 为无状态服务使用hap ...
随机推荐
- Nginx配置文件详解与优化建议
1.概述 今天来详解一下Nginx的配置文件,以及给出一些配置建议,希望能对大家有所帮助. 2.nginx.conf 1)配置文件位置 nginx 安装目录的 conf 文件夹下,例如:/usr/lo ...
- Python之psutil-进程管理
在给PC端应用做自动化测试或者监测应用性能时,不可避免的会与进程管理打交道,python中的psutil模块能够帮助我们处理进程,它主要用于系统监视.分析和限制进程资源以及管理正在运行的进程.一起来了 ...
- Linux下chkconfig
1.chkconfig命令用于检查,设置系统的各种服务! 2.chkconfig语法 chkconfig [--add] [--del] [--list] [系统服务] 或 chkconfig [-- ...
- ThreadLocal原理简单刨析
ThreadLocal原理简单刨析 ThreadLocal实现了各个线程的数据隔离,要知道数据是如何隔离的,就要从源代码分析. ThreadLocal原理 需要提前说明的是:ThreadLocal只是 ...
- HCNP Routing&Switching之动态路由协议IS-IS基础
前文我们了解了OSPF的特殊区域相关话题,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/15236330.html:今天我们来聊一聊另一动态路由协议IS-IS相 ...
- 创建 Spring容器的三种方式
一.src路径下打包完在war包的classes层级下 1.Spring容器创建的三种方式 创建Bean容器之后创建对象: 其中第三种使用的是BeanFactory对象 2.spring通过配置文件用 ...
- Redis-初见
目录 启动and连接 JRedis 宝塔 Redis.conf RDB AOF(Append Only File) 发布和订阅 主从复制 一主二从 复制原理 宕机后的手动配置主机 哨兵模式 Redis ...
- 【第五篇】-Maven 构建配置文件之Spring Cloud直播商城 b2b2c电子商务技术总结
Maven 构建配置文件 构建配置文件是一系列的配置项的值,可以用来设置或者覆盖 Maven 构建默认值. 使用构建配置文件,你可以为不同的环境,比如说生产环境(Production)和开发(Deve ...
- Java实现发送邮件,图片,附件
参照地址 1.JavaMail 介绍 JavaMail 是sun公司(现以被甲骨文收购)为方便Java开发人员在应用程序中实现邮件发送和接收功能而提供的一套标准开发包,它支持一些常用的邮件协议,如前面 ...
- Spring系列-SpringBase+IOC
Spring 一.前言 Thinking is more important than learning 本文主要讲述spring 以及它的 IOC原理 代码地址:https://gitee.com/ ...