首页 > 其他分享 >十七、k8s-helm-初探

十七、k8s-helm-初探

时间:2024-04-03 17:33:08浏览次数:22  
标签:文件 chart yaml 版本 初探 helm k8s

一、为什么要用helm

1.1 常规的部署时通过多个yaml实现的

由于k8s缺少对发布的应用版本管理和控制,使得部署的应用维护和更新等面临诸多挑战,主要体现在以下几方面:

1、如何将这些服务作为一个整体管理

2、这些资源文件如何高效复用

3、不支持应用级别的版本管理

二、helm介绍

Helm是一个k8s的包管理工具,就像linux下的包管理器,如yum、apt、dnf等,可以很方便的将之前打包好的yaml文件部署到k8s上。

Helm有三个重要的概念:

1、helm:一个命令行客户端工具,主要用于k8s应用chart的创建、打包、发布、管理

2、Chart:应用描述,一系列用于描述k8s资源相关文件的集合

3、Release:基于Chart的部署实体,一个chart被Helm运行后将会生成对应一个release;将在k8s中创建出真实运行的资源对象

helm目前有两个大版本:v2和v3: 2019年11月helm团队发布v3版本,相比v2版本最大变化时将tiller删除,并大部分代码重构。

三、helm客户端

使用helm很简单,只需要下载一个二进制客户端包即可,会通过kubeconfig配置(通常$HOME/.kube/config)来连接k8s。

3.1 helm版本与k8s版本兼容性:

https://helm.sh/docs/topics/version_skew/

3.2 下载Helm客户端:

https://github.com/helm/helm/releases

https://get.helm.sh/helm-v3.14.2-linux-amd64.tar.gz

3.3 官网地址:

https://helm.sh/

3.4 安装说明:

# tar -zxf  helm-v3.14.2-linux-amd64.tar.gz

# mv linux-amd64/helm /usr/bin/

3.5 常用命令

四、helm基本使用

4.1 helm create    制作chart

# 创建chart:

mychart

# 打包chart: helm create

helm package mychart

1、chart.yaml:用于描述这个chart的基本信息,包括名字、描述信息以及版本等

2、values.yaml:用于存储templates目录中模板文件中用到变量的值

3、templates:目录里面存放所有yaml模板文件

4、charts:目录里存放这个chart依赖的所有子chart

5、NOTES.txt:用于介绍chart帮助信息,helm install部署后展示给用户。如:如何使用这个chart、列出缺省的设置等

6、_helpers.tpl: 放置模板的地方,可以在整个chart中重复使用。

4.2 helm install 部署

列出部署版本

helm核心是模板,即模板化k8s yaml文件。部署多个应用时,将需要改动的字段进行模板化,可动态传入。

实战:

制作一个纯净的mychart:

删除yaml文件

删除tests目录

清空_helpers.tpl

处理mychart目录下文件:

清空values.yaml文件

删除Chart.yaml文件注释

工作路径

a、将之前部署应用所需的yaml拷贝到templates目录:

使用命令生成pod的yaml,service的yaml使用命令生成时,需要建立在运行的pod之上。

生成yaml文件

修改yaml文件

卸载原有的web

部署web(nginx):

一个deployment部署多个应用,你会修改哪些字段:

a、副本数      b、镜像     c、标签    d、数据卷    e、资源配额    f、健康检查方式     g、镜像拉取策略、拉取认证凭据    h、变量  等

设计变量文件:

修改deployment.yaml文件:

deployment.yaml文件修改:

deployment植入变量

service植入变量

测试运行:

部署报错:

是因为在现有的helm中已经存在了web,现在只需要修改名字即可。

helm已存在web,再次部署报错

修改web名为nginx

4.3 helm upgrade 更新

为了实现Chart复用,可动态传参修改values.yaml中的变量值,有两种方式:

1、--values, -f

2、--set

如升级应用版本:

# helm upgrade --set imageTag=1.18 web mychart

参考:

实战-通过--set 动态修改value.yaml中的变量<差异化动态传参,共用相同地方>:

查看tomcat标签

或者直接修改values.yaml文件:

直接修改values.yaml

4.4 helm rollback 回滚more回滚到上一个版本

回滚指定版本:

# helm rollback nginx 2《版本号:REVISION》

4.5 helm uninstall 卸载

 五、helm工作流程

六、公共cahrt仓库,建议自己写

国内chart仓库,可直接使用它们制作好的包<最好自己写>;

1、 微软:http://mirror.azure.cn/kubernetes/charts/

添加仓库方式:

# helm repo add stable http://mirror.azure.cn/kubernetes/charts

# helm repo add stable https://charts.helm.sh/stable(稳定版本仓库)

 # helm repo add stable Helm Incubator | charts (实验版本仓库)

# helm repo update

# helm repo list

标签:文件,chart,yaml,版本,初探,helm,k8s
From: https://blog.csdn.net/tingting0119/article/details/137352195

相关文章

  • Kubernetes(k8s):如何进行 Kubernetes 集群健康检查?
    Kubernetes(k8s):如何进行Kubernetes集群健康检查?)一、节点健康检查1、使用kubectl查看节点状态2、查看节点详细信息3、检查节点资源使用情况2、Pod健康检查2.1、使用kubectl查看Pod状态2.2、查看特定Pod的详细信息,包括事件和条件3、服务健康检查3.1、使用ku......
  • ( —基础— ) k8s----介绍(1),2024年这些高频面试知识点最后再发一次
    kubectldashboard部署工具:使用批量部署工具如(ansible/saltstack)、手动二进制、apt-get/yum等方式安装,以守护进程的方式启动在宿主机上,类似于是Nginx一样使用service脚本启动。master,node作用Master:是集群的网关和中枢枢纽,主要作用:暴露API接口,跟踪其他服务器......
  • Kubernetes(k8s):部署、使用 metrics-server
    Kubernetes(k8s):部署、使用metrics-server一、metrics-server简介二、部署metrics-server2.1、下载MetricsServer部署文件2.2、修改metrics-server.yaml文件2.3、部署MetricsServer2.4、检查MetricsServer三、使用MetricsServer3.1、查看节点使用情况3.2、......
  • 基础知识-K8s(docker jenkins git)部分
    (0402,更新到Git)资料来源roadmap.sh一小时学会Git|GeekHourDocker部分Docker(容器)到底是什么我的例子预制菜的做法。为了能让使用者都能同一种食材和同一种烹饪方法,我特意在中央厨房,将一种菜式里的食材处理到半熟或者全熟的状态,然后用真空的包装包好,之后在仓库里存放。使......
  • k8s + springcloud 微服务开发调试工具kt Connect的使用
    概览KtConnect(全称KubernetesToolkitConnect)是一款基于Kubernetes环境用于提高本地测试联调效率的小工具。通过这个工具,可以不在本地启动所有服务,只需启动当前开发的服务即可,其它服务使用的是部署在k8s集群的实例,如下图:Reference官方文档:https://github.com/alibaba/......
  • 初探c++:string类的进阶运用
    1.begin()和end(),前一个指向字符串的第一个字符,第二个指向字符串的\0 strings=("helloworld"); string::iteratorit=s.begin(); while(it!=s.end()) { cout<<*it<<""; ++it; } cout<<endl;这是正向迭代器的经典应用如果要实现反向迭代器,就......
  • k8s集群部署
    集群规划软件版本备注操作系统CentOSLinuxrelease7.9.2009(Core)kubernetesv1.29.2dockerDockerversion25.0.3,build4debf41calicov3.27.2角色Ip备注k8s-master-01192.168.11.121k8s-node-01192.168.11.122k8s-node-......
  • K8S 安全监控-falco 二进制部署方式
    基本了解:Falco是一个Linux安全工具,它使用系统调用来保护和监控系统。Falco最初由Sysdig开发,后来加入CNCF孵化器,成为首个加入CNCF的运行时安全项目。Falco提供了一组默认规则,可以监控内核态的异常行为,例如:对于系统目录/etc,/usr/bin,/usr/sbin的读写行为。文件所有权、访问权......
  • Django——初探路由
    第3章初探路由3.1路由定义规则​ 路由称为URL,也可以称为URLconf,是对可以从互联网上得到的资源位置和访问方法的一种简洁的表示,是互联网上标准资源的地址。互联网上的每一个文件都有一个唯一的路由,用于指出网站文件的路径位置。简单地说,路由可视为我们常说的网址,每个网址代表......
  • 记一次 K8s 故障处理
    记一次K8s故障处理k8s技术圈 2024-03-3120:38 四川 听全文 以下文章来源于SRE运维进阶之路 ,作者ClaySRE运维进阶之路.专注于SRE运维、云原生、稳定性、高可用性、可观测性、DevOps等技术 Calico异常重启问题复盘集群内网络架构为,基于CalicoBGP......