zoukankan      html  css  js  c++  java
  • K8s-Helm

    什么是Helm

    • Helm是一个用于k8s的包管理器,使用helm之后就不需要了解k8s的yaml语法并编写应用部署文件,可以通过helm下载并在k8s上安装需要的应用。
    • Helm还提供了k8s的软件部署,删除,升级,回滚应用的强大功能。

    相关术语

    • Helm: 是一个命令行下的客户端工具。主要用于 Kubernetes 应用程序 Chart 的创建、打包、发布以及创建和管理本地和远程的 Chart 仓库。
    • Tiller: 是 Helm 的服务端,部署在 Kubernetes 集群中。Tiller 用于接收 Helm 的请求,并根据 Chart 生成 Kubernetes 的部署文件( Helm 称为 Release ),然后提交给 Kubernetes 创建应用。Tiller 还提供了 Release 的升级、删除、回滚等一系列功能。
    • Chart:Helm 的软件包,采用 TAR 格式。类似于 APT 的 DEB 包或者 YUM 的 RPM 包,其包含了一组定义 Kubernetes 资源相关的 YAML 文件。
    • Repoistory Helm 的软件仓库,Repository 本质上是一个 Web 服务器,该服务器保存了一系列的 Chart 软件包以供用户下载,并且提供了一个该 Repository 的 Chart 包的清单文件以供查询。Helm 可以同时管理多个不同的 Repository。
    • Release: 使用 helm install 命令在 Kubernetes 集群中部署的 Chart 称为 Release。Helm 中提到的 Release 和我们通常概念中的版本有所不同,这里的 Release 可以理解为 Helm 使用 Chart 包部署的一个应用实例。

    Chart Install 过程

    1. Helm从指定的目录或者tgz文件中解析出Chart结构信息
    2. Helm将指定的Chart结构和Values信息通过gRPC传递给Tiller
    3. Tiller根据Chart和Values生成一个Release
    4. Tiller将Release发送给Kubernetes用于生成Release

    Chart Update过程

    1. Helm从指定的目录或者tgz文件中解析出Chart结构信息
    2. Helm将要更新的Release的名称和Chart结构,Values信息传递给Tiller
    3. Tiller生成Release并更新指定名称的Release的History
    4. Tiller将Release发送给Kubernetes用于更新Release

    Chart Rollback过程

    1. Helm将要回滚的Release的名称传递给Tiller
    2. Tiller根据Release的名称查找History
    3. Tiller从History中获取上一个Release
    4. Tiller将上一个Release发送给Kubernetes用于替换当前Release

    Helm Chart 结构

    examples/
      Chart.yaml          # Yaml文件,用于描述Chart的基本信息,包括名称版本等
      LICENSE             # [可选] 协议
      README.md           # [可选] 当前Chart的介绍
      values.yaml         # Chart的默认配置文件
      requirements.yaml   # [可选] 用于存放当前Chart依赖的其它Chart的说明文件
      charts/             # [可选]: 该目录中放置当前Chart依赖的其它Chart
      templates/          # [可选]: 部署文件模版目录,模版使用的值来自values.yaml和由Tiller提供的值
      templates/NOTES.txt # [可选]: 放置Chart的使用指南
    

    Chart.yaml 文件

    name: [必须] Chart的名称
    version: [必须] Chart的版本号,版本号必须符合 SemVer 2:http://semver.org/
    description: [可选] Chart的简要描述
    keywords:
      -  [可选] 关键字列表
    home: [可选] 项目地址
    sources:
      - [可选] 当前Chart的下载地址列表
    maintainers: # [可选]
      - name: [必须] 名字
        email: [可选] 邮箱
    engine: gotpl # [可选] 模版引擎,默认值是gotpl
    icon: [可选] 一个SVG或PNG格式的图片地址
    

    资源

    K8s-安装
    K8s-Pod
    K8s-应用部署
    K8s-Helm

  • 相关阅读:
    工具.MySQL
    SqlServer.日期时间格式化输出(资料)
    SqlServer2012.安装
    SQL.【转】获取存储过程返回值的几种方式
    SQL.【转】SqlServer如何获取存储过程的返回值
    SQL.@,@@、#,##
    Oracle10g.CentOS6安装_遇到的问题(02)
    jQuery FileUpload 插件[转]
    EF6+Oracle12c+DBFirst+VS2015:EF6.0添加实体模型闪退问题解决
    IIS
  • 原文地址:https://www.cnblogs.com/WangJunZzz/p/14460791.html
Copyright © 2011-2022 走看看