k8s学习--Kruise Rollouts 基本使用

2024-06-19 13:04

本文主要是介绍k8s学习--Kruise Rollouts 基本使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • Kruise Rollouts简介
    • 什么是 Kruise Rollouts?
    • 核心功能
  • 应用
    • 环境
      • 一、OpenKruise部署
        • 1.安装helm客户端工具
        • 2. 通过 helm 安装
      • 二、Kruise Rollouts 安装
        • 2. kubectl plugin安装
      • 三、Kruise Rollouts 基本使用(多批次发布)
        • 1. 使用Deployment部署应用
        • 2.准备Rollout对象
        • 将部署升级到“version-2” 并发布第一批次
        • 4. 发布第二批次
        • 5. 发布第三批次
  • 总结


Kruise Rollouts简介

什么是 Kruise Rollouts?

Kruise Rollouts 是由 OpenKruise 开发的 Kubernetes 拓展工具,专门设计用于管理应用部署和更新过程中的复杂需求。它提供了多种高级部署策略,旨在优化和控制 Kubernetes 应用程序的发布过程,使得可以更灵活、更安全地进行版本迭代和回滚。这个工具是对 Kubernetes 标准部署策略(如 RollingUpdate)的扩展和增强。

核心功能

1. 多种部署策略
Kruise Rollouts 支持多种部署策略,包括:
蓝绿部署(Blue-Green Deployment): 快速切换版本,在新旧版本间切换流量,旧版本保持可用直到新版本完全稳定,有利于快速回滚。
金丝雀部署(Canary Deployment): 逐步引入新版本,初期仅向少数用户暴露新版本,逐渐增加曝光率,减少风险。
A/B 测试: 根据特定规则向不同用户展示不同版本,适用于功能测试和用户行为研究。
2. 灵活的流量管理
利用 Istio 等服务网格技术,Kruise Rollouts 可以更精细地控制流量,比如按百分比切分流量到不同版本。
3. 声明式 API
Kruise Rollouts 提供声明式 API,用户可以在 YAML 文件中定义部署策略和规则,Kubernetes 控制器将负责实施这些策略,简化了操作复杂度。
4. 动态配置和更新
支持在不重启容器的情况下动态更改配置,减少因配置变更造成的服务中断。
5. 分阶段发布和验证
可以在部署过程中设置不同的验证点,确保每个阶段的稳定性后再继续推进部署。

使用案例和好处

更安全的部署: 通过多种部署策略,尤其是蓝绿和金丝雀策略,可以显著降低新版本引入问题的风险。
连续部署: Kruise Rollouts 支持 CI/CD 流程,使得应用更新更加流畅和自动化。
实验性功能测试:A/B 测试支持让开发者能够测试新功能对特定用户群体的影响。

实现方式

Kruise Rollouts 是作为一个 Kubernetes Operator 实现的。它监听自定义资源的变化,然后按照定义的规则调整 Kubernetes 的 Service、Deployment 等资源,以实现精细的版本控制和流量管理。

与其他工具的对比

与 Kubernetes 原生的 Deployment 和其他部署工具(如 Spinnaker、Argo Rollouts)相比,Kruise Rollouts 提供了更为丰富的功能和更高的灵活性,尤其是在复杂的生产环境中。它通过扩展和增强原生 Kubernetes 功能,提供了更适合企业级应用的部署选项。

应用

环境

虚拟机

Ip主机名cpu内存硬盘
192.168.10.11master012cpu双核4G100G
192.168.10.12worker012cpu双核4G100G
192.168.10.13worker022cpu双核4G100G

版本 centos7.9
已部署k8s-1.27

一、OpenKruise部署

本案例使用helm方式安装部署

Helm用于实现kubernetes中相互关联的多个yaml文件的安装部署,相当于linux系统中的yum工具

1.安装helm客户端工具
wget https://get.helm.sh/helm-v3.13.2-linux-amd64.tar.gz
tar xf helm-v3.13.2-linux-amd64.tar.gz
mv linux-amd64/helm /usr/bin/
helm version
helm repo add stable http://mirror.azure.cn/kubernetes/charts/
helm repo add bitnami https://charts.bitnami.com/bitnami
helm repo add prometheus-community https://prometheus-community.github.io/helm-charts
helm repo update
helm repo list

详情请看
链接: k8s学习–helm的详细解释及安装和常用命令

2. 通过 helm 安装
helm repo add openkruise https://openkruise.github.io/charts/helm repo updatehelm search repo openkruise

搜索OpenKruise仓库中的Charts
可以看到已经存在
在这里插入图片描述

由于本次部署在K8S 1.27版本集群,并使用cri-dockerd,所以手动指定CRI。
注意:如果是1.24以下,则不需要,因为默认就是docker

helm install kruise openkruise/kruise --version 1.6.3 --set daemon.socketLocation=/var/run --set daemon.socketFile=cri-dockerd.sock

在这里插入图片描述
查看一下

helm list

在这里插入图片描述

kubectl  -n kruise-system get all

可以看到都已经运行起来了
在这里插入图片描述

二、Kruise Rollouts 安装

添加openkruise charts库

 helm repo add openkruise https://openkruise.github.io/charts/helm repo update

安装最新版本

helm install kruise-rollout openkruise/kruise-rollout --version 0.5.0
kubectl get ns

已经可以看到kruise-rollout的命令空间了
在这里插入图片描述

kubectl get pods -n kruise-rollout

在这里插入图片描述

2. kubectl plugin安装

注:需要科学上网

wget https://github.com/openkruise/kruise-tools/releases/download/v1.1.2/kubectl-kruise-linux-amd64.tar.gz
tar xf kubectl-kruise-linux-amd64.tar.gz 
mv linux-amd64/kubectl-kruise /usr/bin/
kubectl version --output=yaml

在这里插入图片描述

三、Kruise Rollouts 基本使用(多批次发布)

1. 使用Deployment部署应用
vim 01-deployment.yaml 
apiVersion: apps/v1
kind: Deployment
metadata:name: workload-demonamespace: default
spec:replicas: 10selector:matchLabels:app: demotemplate:metadata:labels:app: demospec:containers:- name: busyboximage: busybox:latestcommand: [ "/bin/sh", "-c", "sleep 100d" ]env:- name: VERSIONvalue: "version-1"

应用yaml文件

kubectl apply -f 01-deployment.yaml

查看pod

kubectl get pods

在这里插入图片描述

2.准备Rollout对象
vim 02-rollout.yaml
apiVersion: rollouts.kruise.io/v1alpha1
kind: Rollout
metadata:name: rollouts-demonamespace: defaultannotations:rollouts.kruise.io/rolling-style: partition # 指示 Rollout 使用分区方式进行滚动更新
spec:objectRef:workloadRef:apiVersion: apps/v1kind: Deploymentname: workload-demostrategy:canary:steps:- replicas: 1- replicas: 50%- replicas: 100%

应用yaml文件

kubectl apply -f 02-rollout.yaml 

查看rollout

kubectl get rollout

在这里插入图片描述

将部署升级到“version-2” 并发布第一批次
kubectl get pods

在这里插入图片描述

kubectl get deployments.apps 

在这里插入图片描述

下列命令是用来更新名为 workload-demo 的部署(Deployment),将容器的环境变量 VERSION 设置为 version-2。

kubectl patch deployment workload-demo -p '{"spec":{"template":{"spec":{"containers":[{"name":"busybox", "env":[{"name":"VERSION", "value":"version-2"}]}]}}}}'

然后查看

kubectl get pods

可以看到添加了一个pod
第一次更新可能会多创建一个Pod的原因主要是为了在不影响现有服务的前提下进行新版本的测试和验证
在这里插入图片描述

4. 发布第二批次
 kubectl-kruise rollout approve rollouts/rollouts-demokubectl get rollout

在这里插入图片描述
查看pod

kubectl get pod

可以看到增加了5个
在这里插入图片描述

5. 发布第三批次
kubectl-kruise rollout approve rollouts/rollouts-demo
kubectl get rollouts

在这里插入图片描述
稍等一会查看

kubectl get pod

在这里插入图片描述
再稍等一会
可以看到旧的pod逐渐被删除,最后只剩下新的pod

kubectl get pod

在这里插入图片描述

kubectl get replicasets

在这里插入图片描述

总结

总结来说,Kruise Rollouts 是 Kubernetes 生态中的一个重要拓展,适用于需要高度可控和自动化部署策略的复杂应用环境。

这篇关于k8s学习--Kruise Rollouts 基本使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1075110

相关文章

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

Python中配置文件的全面解析与使用

《Python中配置文件的全面解析与使用》在Python开发中,配置文件扮演着举足轻重的角色,它们允许开发者在不修改代码的情况下调整应用程序的行为,下面我们就来看看常见Python配置文件格式的使用吧... 目录一、INI配置文件二、YAML配置文件三、jsON配置文件四、TOML配置文件五、XML配置文件

Go使用pprof进行CPU,内存和阻塞情况分析

《Go使用pprof进行CPU,内存和阻塞情况分析》Go语言提供了强大的pprof工具,用于分析CPU、内存、Goroutine阻塞等性能问题,帮助开发者优化程序,提高运行效率,下面我们就来深入了解下... 目录1. pprof 介绍2. 快速上手:启用 pprof3. CPU Profiling:分析 C

MySQL InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据

《MySQLInnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据》mysql的ibdata文件被误删、被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所有表数据... 参考:mysql Innodb表空间卸载、迁移、装载的使用方法注意!此方法只适用于innodb_fi

Python中conda虚拟环境创建及使用小结

《Python中conda虚拟环境创建及使用小结》本文主要介绍了Python中conda虚拟环境创建及使用小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录0.前言1.Miniconda安装2.conda本地基本操作3.创建conda虚拟环境4.激活c

Spring中@Lazy注解的使用技巧与实例解析

《Spring中@Lazy注解的使用技巧与实例解析》@Lazy注解在Spring框架中用于延迟Bean的初始化,优化应用启动性能,它不仅适用于@Bean和@Component,还可以用于注入点,通过将... 目录一、@Lazy注解的作用(一)延迟Bean的初始化(二)与@Autowired结合使用二、实例解

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J

Spring Boot 中正确地在异步线程中使用 HttpServletRequest的方法

《SpringBoot中正确地在异步线程中使用HttpServletRequest的方法》文章讨论了在SpringBoot中如何在异步线程中正确使用HttpServletRequest的问题,... 目录前言一、问题的来源:为什么异步线程中无法访问 HttpServletRequest?1. 请求上下文与线

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

从零教你安装pytorch并在pycharm中使用

《从零教你安装pytorch并在pycharm中使用》本文详细介绍了如何使用Anaconda包管理工具创建虚拟环境,并安装CUDA加速平台和PyTorch库,同时在PyCharm中配置和使用PyTor... 目录背景介绍安装Anaconda安装CUDA安装pytorch报错解决——fbgemm.dll连接p