k8s Deployment 升级应用1

简介: k8s Deployment 升级应用1

上一次我们分享到,如何去升级一个 pod 的新的版本,相信在理论上,大家都知道可以如何做了,那么我们来进行实践一下,看看都会遇到哪些问题,以及操作起来是否便捷,感兴趣的可以一起来体验一波

本来是可以使用 rolling-update 的方式

使用 rolling-update 的方式,其实对于 k8s 来说已经是过时了的,但是我们还是要来了解和尝试一下rolling-update 的方式 ,在这里我们先说一下为啥他会被淘汰

因为使用 rolling-update 的方式其实是会直接修改我们创建出来的对象的,这回导致直接更新 pod 和 RS 的标签,这种做法还是不太好,而且现在最新的 k8s 也不支持了

对于先删除旧的,然后创建新的,这个方式比较简单,就是使用 RS 的扩容和缩容拉实现,之前的分享的事件案例中就有所涉及,我们可以再来温习一遍

我们可以使用这两种方式

  • RS 扩缩容的方式
  • deployment

RS 扩缩容的方式

创建必备基本环境

写一个应用程序,可以标识版本

app.js

const http = require('http');
const os = require('os');
console.log("xmt kubia server starting...");
var handler = function(request, response){
    console.log("received request from " + request.connection.remoteAddress);
    response.writeHead(200);
    response.end("you've hit xmt web  " + os.hostname() + "version is v1"  "\n");
};
var www = http.createServer(handler);
www.listen(8080);

自己可以继续复用之前的一个小应用,简单的 http 请求,访问应用的 8080 端口后,应用会给客户端 pod 的 名字和 版本号 v1

做一个镜像

Dockerfile

FROM node:7
ADD app.js /app.js
ENTRYPOINT ["node", "app.js"]

我们将上述的小应用加入到 Dockerfile 中,直接运行即可

docker build -t xiaomotong888/newkubia:v1
docker push xiaomotong888/newkubia:v1

写 yaml ,创建 RS,Service,Pod

mynewkubia.yaml

apiVersion: v1
kind: Service
metadata:
  name: newkubia-service
spec:
  type: NodePort
  selector:
    app: newkubia
  ports:
  - port: 80
    targetPort: 8080
---
apiVersion: apps/v1
kind: ReplicaSet
metadata:
  name: newkubia-rs
spec:
  replicas: 3
  selector:
    matchLabels:
      app: newkubia
  template:
    metadata:
      labels:
        app: newkubia
    spec:
      containers:
      - name: newkubia
        image: xiaomotong888/newkubia:v1
        ports:
        - containerPort: 8080

创建一个 SVC 和 RS,可以放在同一个 yaml 文件中一起部署,我们只需要用 --- 隔开即可

使用 kubectl create -f mynewkubia.yaml即可创建出 RS ,SVC 和 POD

此处的 SVC 本来是想模拟 LoadBalancer 的,但是我使用的是 minikube ,没有办法使用 LoadBalancer,不过我可以使用 NodePort 的类型

我们可以进入任意一个 pod ,是用 curl 命令访问 服务的地址(svc),我们可以看到如下效果

能够看到访问此时的服务打印出来的消息是 v1 版本的,没有毛病

开始创建一个新的 RS2,将流量切换到新的 Pod 中

这个时候,我们来创建另外一个 RS2,然后通过修改标签的方式,来将 Service 的流量切换到新的 pod 中

具体的 yaml 内容 和上述的 RS yaml 内容一致,我们只需要将对应的地方修改为 newkubia-rs-2 即可,不要和之前创建的 RS 冲突了,标签也要一起修改

kubectl create 对应的 yaml 文件之后 ,我们在进入到 对应的 SVC 修改 标签

这个时候我们再来查看一下流量是否真的会去切换到 pod v2 版本上

我们仍然可以使用同样的方式,找到任意一个 pod ,进入到容器,通过 curl 命令访问 svc 的地址,查看日志给我们输出的是什么效果

通过查看效果响应的是 v2 版本的,我们可以知道,Service 的流量确实且到了新的 pod , 对应这个请求的路径是这个样子的:

这个图,我们在分享 Service 的时候,也有体现。

今天就到这里,学习所得,若有偏差,还请斧正

欢迎点赞,关注,收藏

朋友们,你的支持和鼓励,是我坚持分享,提高质量的动力

好了,本次就到这里

技术是开放的,我们的心态,更应是开放的。拥抱变化,向阳而生,努力向前行。

我是阿兵云原生,欢迎点赞关注收藏,下次见~

更多的可以查看 零声每晚八点直播:https://ke.qq.com/course/417774

相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
25天前
|
Kubernetes 网络协议 网络安全
提升你的云技能:深入了解CKA认证之k8s升级秘籍!
提升你的云技能:深入了解CKA认证之k8s升级秘籍!
19 0
|
14天前
|
Kubernetes 监控 Cloud Native
构建高效云原生应用:基于Kubernetes的微服务治理实践
【4月更文挑战第13天】 在当今数字化转型的浪潮中,企业纷纷将目光投向了云原生技术以支持其业务敏捷性和可扩展性。本文深入探讨了利用Kubernetes作为容器编排平台,实现微服务架构的有效治理,旨在为开发者和运维团队提供一套优化策略,以确保云原生应用的高性能和稳定性。通过分析微服务设计原则、Kubernetes的核心组件以及实际案例,本文揭示了在多变的业务需求下,如何确保系统的高可用性、弹性和安全性。
17 4
|
14天前
|
JSON Kubernetes Go
无缝集成:在IntelliJ IDEA中利用Kubernetes插件轻松管理容器化应用
无缝集成:在IntelliJ IDEA中利用Kubernetes插件轻松管理容器化应用
25 0
无缝集成:在IntelliJ IDEA中利用Kubernetes插件轻松管理容器化应用
|
25天前
|
消息中间件 Kubernetes Kafka
Terraform阿里云创建资源1分钟创建集群一键发布应用Terraform 创建 Kubernetes 集群
Terraform阿里云创建资源1分钟创建集群一键发布应用Terraform 创建 Kubernetes 集群
18 0
|
1月前
|
边缘计算 Kubernetes 负载均衡
容器编排技术在云计算中的应用
随着云计算技术的飞速发展,容器编排技术作为一种重要的部署和管理工具,正在逐渐成为云计算领域的热门话题。本文将介绍容器编排技术在云计算中的应用,探讨其在提高应用程序部署效率、资源利用率以及系统可靠性方面的优势,并分析其未来发展趋势。
|
1月前
|
人工智能 自然语言处理 Kubernetes
LLM 技术图谱(LLM Tech Map)& Kubernetes (K8s) 与AIGC的结合应用
LLM 技术图谱(LLM Tech Map)& Kubernetes (K8s) 与AIGC的结合应用
81 0
|
2月前
|
JavaScript NoSQL Redis
深入浅出:使用 Docker 容器化部署 Node.js 应用
在当今快速发展的软件开发领域,Docker 作为一种开源的容器化技术,已经成为了提高应用部署效率、实现环境一致性和便于维护的关键工具。本文将通过一个简单的 Node.js 应用示例,引导读者从零开始学习如何使用 Docker 容器化技术来部署应用。我们不仅会介绍 Docker 的基本概念和操作,还会探讨如何构建高效的 Docker 镜像,并通过 Docker Compose 管理多容器应用。此外,文章还将涉及到一些最佳实践,帮助读者更好地理解和应用 Docker 在日常开发和部署中的强大功能。
106 0
|
2月前
|
消息中间件 Kubernetes NoSQL
「译文」K8S 及 OpenShift 上应用程序的 Labels 和 Annotations 最佳实践
「译文」K8S 及 OpenShift 上应用程序的 Labels 和 Annotations 最佳实践
|
存储 设计模式 运维
YAML 管理 Kubernetes 应用
YAML 管理 Kubernetes 应用
266 1
|
存储 设计模式 运维
如何不编写 YAML 管理 Kubernetes 应用?
Kubernetes 将自身边界内的事物都抽象为资源。其中的主要部分,是以 Deployment、StatefulSet 为代表的 workload 工作负载控制器,其他各类资源都围绕这些主要的资源工作。这些资源合并起来,可以为 IT 技术工作者展现出一个以 workload 为中心的模型。Kubernetes 中所有的资源,都通过声明式配置文件来编辑描述,一条条的 Yaml 字段定义,给了 IT 技术人员最大的自由度的同时,也对技术人员的能力提出了极高的要求。