Helm 是一个命令行下的客户端工具。主要用于 Kubernetes 应用程序 Chart 的创建
、打包
、发布
以及创建管理本地或者远程的Chart仓库
。
- 如何统一管理、配置和更新分散的
k8s yaml
资源文件 - 如何分发和复用一套应用模板
- 如何将应用的一系列资源当做一个软件包管理
- 如何统一下架一个服务在k8s创建的所有资源
-
Release
不再是全局资源,而是存储在各自命名空间内 -
Helm 2
默认情况下使用ConfigMaps
存储版本信息。在Helm 3
中,将Secrets
用作默认存储驱动程序 -
把
requirements.yaml
合并成Chart.yaml
-
helm install
需要提供名称,如果实在不想提供名称,指定参数--generate-name
,在v2时可以不提供,不提供名称时将自动生成一个名称,这功能比较令人讨厌 -
去除用于本地临时搭建
Chart Repository
的helm serve
命令 -
Values
支持JSON Schema
校验器,自动检查所有输入的变量格式 -
helm cli
命令重命名
# v2中删除项目需要提供--purge参数,v3默认情况下启用此功能。要保留以前的行为,请使用 helm uninstall --keep-history
helm delete 重命名为 helm uninstall
helm fetch 重命名为 helm pull
helm inspect 重命名为 helm show
以上命令虽然重命名,但旧命令仍然可用
- 创建的命名空间不存在时,在
helm 2
会自动创建命名空间,helm 3
会遵守Kubernetes
行为,返回错误