Helm是一个用于管理Kubernetes包(称为chart)的工具。Helm可以做到以下几点:
- 从头创建新chart
- 将chart打包成chart归档(tgz)文件
- 与存储chart的chart仓库交互
- 在现有的Kubernetes集群中安装和卸载chart
- 管理已安装Helm Chart的发布周期
Helm相关重要的概念:
1.Chart: Helm 的软件包,采用 TAR 格式。chart是创建Kubernetes应用程序实例所需的一组信息。
- config: config包含配置信息,可以将这些配置信息合并到一个打包的Chart中,以创建一个可发布的对象。
- release: chart的运行实例,并且与特定的配置(config)相结合。
- Repoistory:Helm 的软件仓库,Repository 本质上是一个 Web 服务器,该服务器保存了一系列的 Chart 软件包以供用户下载,并且提供了一个该 Repository 的 Chart 包的清单文件以供查询。Helm 可以同时管理多个不同的 Repository。Helm允许我们创建私有chart仓库。
组件
Helm有两个主要的组件:
Helm客户端:
是终端用户的命令行客户端。客户端有以下职责:
- 本地chart开发
- 管理仓库
- 与Tiller服务端交互
- 发送chart以安装
- 询问关于发布的信息
- 请求升级或卸载已存在的发布
Tiller服务端:
是一个集群内的服务器,它与Helm客户端交互,并与Kubernetes API服务器对接。服务端有以下职责:
- 监听来自Helm客户端的传入请求
- 结合chart和配置来构建一个发布
- 安装chart至Kubernetes,并且跟踪后续的发布
- 与Kubernetes交互,升级与卸载chart
简而言之,客户端负责管理chart,而服务端负责管理发布。架构图如下:
架构图
Chart 文件结构
chart是一个组织在文件目录中的集合。
wordpress/
Chart.yaml # 包含了chart信息的YAML文件
LICENSE # 可选: 包含chart许可证的纯文本文件
README.md # 可选: 可读的README文件
values.yaml # chart 默认的配置值
values.schema.json # 可选: 一个使用JSON结构的values.yaml文件
charts/ # 包含chart依赖的其他chart
crds/ # 自定义资源的定义
templates/ # 模板目录, 当和values 结合时,可生成有效的Kubernetes manifest文件
templates/NOTES.txt # 可选: 包含简要使用说明的纯文本文件
Chart.yaml文件是chart必需的。包含了以下字段:
apiVersion: chart API 版本 (必需)
name: chart名称 (必需)
version: 语义化2 版本(必需)
kubeVersion: 兼容Kubernetes版本的语义化版本(可选)
description: 一句话对这个项目的描述(可选)
type: chart类型 (可选)
keywords:
- 关于项目的一组关键字(可选)
home: 项目home页面的URL (可选)
sources:
- 项目源码的URL列表(可选)
dependencies: # chart 必要条件列表 (可选)
- name: chart名称 (nginx)
version: chart版本 ("1.2.3")
repository: 仓库URL ("https://example.com/charts") 或别名 ("@repo-name")
condition: (可选) 解析为布尔值的yaml路径,用于启用/禁用chart (e.g. subchart1.enabled )
tags: # (可选)
- 用于一次启用/禁用 一组chart的tag
enabled: (可选) 决定是否加载chart的布尔值
import-values: # (可选)
- ImportValue 保存源值到导入父键的映射。每项可以是字符串或者一对子/父列表项
alias: (可选) chart中使用的别名。当你要多次添加相同的chart时会很有用
maintainers: # (可选)
- name: 维护者名字 (每个维护者都需要)
email: 维护者邮箱 (每个维护者可选)
url: 维护者URL (每个维护者可选)
icon: 用做icon的SVG或PNG图片URL (可选)
appVersion: 包含的应用版本(可选)。不需要是语义化的
deprecated: 不被推荐的chart (可选,布尔值)
annotations:
example: 按名称输入的批注列表 (可选).
Chart 安装过程:
-
Helm从指定的目录或者tgz文件中解析出Chart结构信息
-
Helm将指定的Chart结构和Values信息通过gRPC传递给Tiller
-
Tiller根据Chart和Values生成一个Release
-
Tiller将Release发送给Kubernetes用于生成Release
helm基础操作命令:
查看已安装的chart列表
$ helm list -A
查看更新repo
$ helm repo list
$ helm repo update
删除releases
helm delete chartsnames
打包chart:
$ helm package hello-helm
查看历史版本
$ helm history chartsname
回滚到旧版本:
$ helm rollback chartsname chartsname-before
搜索chart包
$ helm search
$ helm search redis
查看chart详细信息:
$ helm inspect stable/mysql
安装chart:
$ helm install stable/mysql
网友评论