zoukankan      html  css  js  c++  java
  • k8s~helm的介绍

    Helm 是什么

    1. Helm 是 Deis 开发的一个用于 Kubernetes 应用的包管理工具,主要用来管理 Charts。有点类似于 Ubuntu 中的 APT 或 CentOS 中的 YUM。
    2. Helm Chart 是用来封装 Kubernetes 原生应用程序的一系列 YAML 文件。可以在你部署应用的时候自定义应用程序的一些 Metadata,以便于应用程序的分发。
      对于应用发布者而言,可以通过 Helm 打包应用、管理应用依赖关系、管理应用版本并发布应用到软件仓库。
    3. 对于使用者而言,使用 Helm 后不用需要编写复杂的应用部署文件,可以以简单的方式在 Kubernetes 上查找、安装、升级、回滚、卸载应用程序。

    做为 Kubernetes 的一个包管理工具,Helm具有如下功能:

    1. 创建新的 chart
    2. chart 打包成 tgz 格式
    3. 上传 chart 到 chart 仓库或从仓库中下载 chart
    4. 在Kubernetes集群中安装或卸载 chart
    5. 管理用Helm安装的 chart 的发布周期

    Helm 组件及相关术语

    本文中讲到的是helm V2最新版本,V3版本也已经发布了beta版,在 Helm 3 中,Tiller 被移除了。

    • Helm
      Helm 是一个命令行下的客户端工具。主要用于 Kubernetes 应用程序 Chart 的创建、打包、发布以及创建和管理本地和远程的 Chart 仓库。

    • Tiller
      Tiller 是 Helm 的服务端,部署在 Kubernetes 集群中。Tiller 用于接收 Helm 的请求,并根据 Chart 生成 Kubernetes 的部署文件( Helm 称为 Release ),然后提交给 Kubernetes 创建应用。Tiller 还提供了 Release 的升级、删除、回滚等一系列功能。

    • Chart
      包含了创建Kubernetes的一个应用实例的必要信息,Helm 的软件包,采用 TAR 格式。类似于 APT 的 DEB 包或者 YUM 的 RPM 包,其包含了一组定义 Kubernetes 资源相关的 YAML 文件。

    • Repoistory
      Helm 的软件仓库,Repository 本质上是一个 Web 服务器,该服务器保存了一系列的 Chart 软件包以供用户下载,并且提供了一个该 Repository 的 Chart 包的清单文件以供查询。Helm 可以同时管理多个不同的 Repository。

    • Release
      是一个 chart 及其配置的一个运行实例,使用 helm install 命令在 Kubernetes 集群中部署的 Chart 称为 Release。

    Helm 工作流程

    • Chart Install 过程
      Helm 从指定的目录或者 TAR 文件中解析出 Chart 结构信息。
      Helm 将指定的 Chart 结构和 Values 信息通过 gRPC 传递给 Tiller。
      Tiller 根据 Chart 和 Values 生成一个 Release。
      Tiller 将 Release 发送给 Kubernetes 用于生成 Release。

    • Chart Update 过程
      Helm 从指定的目录或者 TAR 文件中解析出 Chart 结构信息。
      Helm 将需要更新的 Release 的名称、Chart 结构和 Values 信息传递给 Tiller。
      Tiller 生成 Release 并更新指定名称的 Release 的 History。
      Tiller 将 Release 发送给 Kubernetes 用于更新 Release。

    • Chart Rollback 过程
      Helm 将要回滚的 Release 的名称传递给 Tiller。
      Tiller 根据 Release 的名称查找 History。
      Tiller 从 History 中获取上一个 Release。
      Tiller 将上一个 Release 发送给 Kubernetes 用于替换当前 Release。

    • Chart 处理依赖说明
      Tiller 在处理 Chart 时,直接将 Chart 以及其依赖的所有 Charts 合并为一个 Release,同时传递给 Kubernetes。因此 Tiller 并不负责管理依赖之间的启动顺序。Chart 中的应用需要能够自行处理依赖关系。

  • 相关阅读:
    命令行程序测试自动化
    微软的PivotViewer控件编程续
    使用Autofac实现依赖注射及Ioc
    微软的PivotViewer控件编程
    求最大公约数(GCD)的两种算法
    编译原理学习笔记一(待续)
    如果你想创业,又担心腾讯照抄你的好点子的话,可以看看下面的文章。
    从测试的角度来重新反思我们自己的程序以及我们的程序员之路——“通过追本溯源来进行前瞻性思考”
    Ubuntu11.10安装飞信
    2012.3.27《JAVA程序设计教程》
  • 原文地址:https://www.cnblogs.com/lori/p/12651904.html
Copyright © 2011-2022 走看看