Helm3 部署使用

Helm 是 Kubernetes 的包管理器,这里下载的是 3.4.1 版本:其它版本请或者其它系统请移步官网:https://helm.sh/zh/docs/intro/install/
wget https://get.helm.sh/helm-v3.4.1-linux-amd64.tar.gz
tar -zxvf helm-v3.4.1-linux-amd64.tar.gz
cd linux-amd64/
cp helm /usr/bin
chmod a+x /usr/bin/helm

访问 Helm 仓库:https://artifacthub.io/

Helm常用命令
[root@master ~]# helm version        //查看helm版本信息
[root@master ~]# helm list               /查看当前安装的Chart包
[root@master ~]# helm search mysql         //查看与mysql相关的chart包
[root@master ~]# helm fetch stable/mysql            //将mysql软件包下载到本地
[root@master ~]# helm inspect stable/mysql       //查看该软件包的详细信息
[root@master ~]# helm install stable/mysql -n mysql        //安装指定的mysql软件包,并命名为mysql
[root@master ~]# helm status mysql                 //查看mysql的状态信息
[root@master ~]# helm delete --purge mysql       //删除mysql,并将本地的缓存也进行删除
[root@master ~]# helm repo add stable https://kubernetes.oss-cn-hangzhou.aliyuncs.com/charts
//添加阿里云的repo源
[root@master ~]# helm repo update              //更新repo仓库资源
[root@master ~]# helm create helm_charts       //创建一个chart,名称为helm_charts
[root@master ~]# cd helm_charts/ && helm lint       //测试charts语法
[root@master ~]# helm package helm_charts           //打包charts
[root@master helm_charts]# helm template helm_charts-0.1.0.tgz       //查看该软件包生成的yaml文件

搜索需要的包
按照 install 步骤操作即可

Helm 自定义模板
chart 是一个组织在文件目录中的集合。

在这个目录中,Helm 期望可以匹配以下结构:

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.yaml 文件是 chart 必需的。包含了以下字段:

apiVersion: chart API 版本 (必需)
name: chart名称 (必需)
version: 版本(必需)
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: 按名称输入的批注列表 (可选).

apiVersion:在 Helm3 中,apiVersion=v2;在 Helm3 之前的版本,apiVersion=v1
内置对象
(1) Values

Values 对象是为 Chart 模板提供值,这个对象的值有4个来源,后面的可以覆盖前面的:

chart 包中的 values.yaml 文件
父 chart 包的 values.yaml 文件
通过 helm install 或者 helm upgrade 的 -f 或者 --values 参数传入的自定义的 yaml 文件
通过 --set 参数传入的值

在模板文件中,通过 {{.Values}} 对象来访问设置的值。

posted @ 2021-04-21 15:14  一毛丶丶  阅读(723)  评论(0编辑  收藏  举报