由于k8s缺少对发布的应用版本管理和控制,使得部署的应用维护和更新等面临诸多挑战,主要体现在以下几方面:
1、如何将这些服务作为一个整体管理
2、这些资源文件如何高效复用
3、不支持应用级别的版本管理
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很简单,只需要下载一个二进制客户端包即可,会通过kubeconfig配置(通常$HOME/.kube/config)来连接k8s。
https://helm.sh/docs/topics/version_skew/
https://github.com/helm/helm/releases
https://get.helm.sh/helm-v3.14.2-linux-amd64.tar.gz
https://helm.sh/
# tar -zxf helm-v3.14.2-linux-amd64.tar.gz
# mv linux-amd64/helm /usr/bin/
# 创建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中重复使用。
列出部署版本:
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
为了实现Chart复用,可动态传参修改values.yaml中的变量值,有两种方式:
1、--values, -f
2、--set
如升级应用版本:
# helm upgrade --set imageTag=1.18 web mychart
参考:
实战-通过--set 动态修改value.yaml中的变量<差异化动态传参,共用相同地方>:
查看tomcat标签
或者直接修改values.yaml文件:
直接修改values.yaml
回滚指定版本:
# helm rollback nginx 2《版本号:REVISION》
国内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