前言:
    Helm是Kubernetes的一个重要附件,里面涉及到的一些目录层级,配置模板,还有相互之间的关系,是需要提前了解一下的

    Helm - 整体目录结构:
    image.png

    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 # 可选: 包含简要使用说明的纯文本文件

    Helm - Chart Yaml:
    image.png

    PS:apiVersion:
    在 Helm3 中,apiVersion=v2
    在 Helm3 之前的版本,apiVersion=v1

    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: 按名称输入的批注列表 (可选)

    Hlem - 内置对象 - Values:
    image.png
    Values 对象是为 Chart 模板提供值,这个对象的值有4个来源,后面的可以覆盖前面的:

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

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

    image.png
    apiVersion: v1
    kind: Pod
    metadata:
    name: test
    spec:
    template:
    spec:
    containers:
    - name: nginx
    image: {{ .Values.image.repository }}:{{ .Values.image.tag }}
    ports:
    - containerPort: 80
    protocol: TCP

    相关文档:https://www.cnblogs.com/wuxinchun/p/15308687.html