本期文章是K8s特别篇,主要是速通学习Helm之简介、仓库、实践应用等。通过本期文章:我们将学习Helm的基础知识、简介、仓库、实践应用等
在前期的文章中,已经介绍了一些云原生入门的知识及简单实战,感兴趣的同学可以去我的云原生专栏中学习,任意门:云原生学习专栏
用过Ubuntu和CentOS的同学都不陌生,Ubuntu下的ap-get或者CentOS下的yum,都是Linux系统下的包管理工具。采用这两个管理工具,开发者可以管理应用包之间的依赖关系,发布应用,同时用户可以以简单的方式查找、安装、升级、卸载应用程序。
那么通过类比,Helm就是Kubernetes的apt-get/yum。Helm是Deis开发的一个用于kubernetes的包管理器。每个包都称为一个Chart,一个Chart是一个目录。
应用发布者可以通过Helm打包应用,管理应用依赖关系,管理应用版本并发布应用到软件仓库。
使用者可以使用Helm但是并不需要了解K8s的Yaml语法并编写应用部署文件,可以通过Helm下载并在kubernetes上安装需要的应用。也就是通过Helm可以使用一条命令就能够将其部署安装在自己的Kubernetes集群中。Helm还可以提供软件部署、删除、升级、回滚应用等功能。
先来看看直接应用Kubernetes部署云服务可能会遇到的困难?
Kubernetes使用yaml文件来描述和管理服务中各个组件的配置和部署需求,每个组件对应一个yaml文件。云服务通常都是由多个组件构成的,如何配置和处理好这些组件即多个yaml文件之间的关联关系,成为了Kubernetes应用的必须面对的。
当云服务升级只涉及其中一个或某几个模块时,升级模块的新yaml文件和已有yaml文件之间的关联关系会变得更加复杂,增加了使用Kubernetes来配置和管理升级的难度。
另外,Kubernetes把组件的配置信息也直接记录到yaml文件当中。从描述组件的角度来讲,这种方式确实比较清晰。但是,当云服务的部署面对多个环境,如不同的开发、测试、产品环境(当前比较常见的应用场景),要如何处理这些环境配置之间的差别呢?为每个环境都开发和维护一套不同的yaml文件?这显然增加了许多工作量。
并且,Kubernetes的yaml文件本身是没有版本的概念的。当某次部署失败,需要回滚到上一个稳定版本,该选择哪一套yaml文件来处理也成了需要解决的额外问题。
所以,Helm可以很好的解决这些问题。Helm是通过被称作Helm Chart的包来描述和管理云服务的。
Helm的架构由Helm客户端、Tiller服务器端和Chart仓库所组成;Tiller部署在Kubernetes中,Helm客户端从Chart仓库中获取Chart安装包,并将其安装部署到Kubernetes集群中。
Helm客户端:这是一个供终端用户使用的命令行工具,客户端负责如下的工作:
Helm客户端是使用Go语言编写的,它通过gRPC协议与Tiller服务器交互。
Tiller服务部署在Kubernetes集群中,Helm客户端通过与Tiller服务器进行交互,并最终与Kubernetes API服务器进行交互。 Tiller服务器负责如下的工作:
Tiller服务器也是使用Go语言编写的,它使用Kubernetes客户端类库与Kubernetes进行通讯。
先简单创建个chart:
helm create myapp
//chart的目录结构
# tree myapp/
myapp/
├── charts
├── Chart.yaml
├── templates
│ ├── deployment.yaml
│ ├── _helpers.tpl
│ ├── ingress.yaml
│ ├── NOTES.txt
│ ├── serviceaccount.yaml
│ ├── service.yaml
│ └── tests
│ └── test-connection.yaml
└── values.yaml
在上面的功能中,有三个重要概念要理解:
那么,helm的运行流程如下:
首先,从chart仓库中获取chart,然后开发者配置自己的values文件,根据自己的运行环境对values进行修改,然后默认values文件和使用者values文件会进行一个merge,形成最终的values文件;使用最终的values文件,渲染chart的template,形成可以被kubernetes执行的yaml,最后调用kube apply提交yaml到kubernetes。
在上述的过程中,使用者只需要理解一点点配置的知识就可以完成操作,没有那么困难了。这也正是helm的核心设计理念。
curl https://baltocdn.com/helm/signing.asc | sudo apt-key add –
sudo apt-get install apt-transport-https --yes
echo "deb https://baltocdn.com/helm/stable/debian/ all main" | sudo tee /etc/apt/sources.list.d/helm-stable-debian.list
sudo apt-get update
sudo apt-get install helm=3.4.2-1
添加仓库:helm repo add stable https://charts.helm.sh/stable
查看已经添加的仓库:helm repo list
搜索仓库有哪些chart:helm search repo stable
更新仓库列表到本地:helm repo update
搜索redis:helm search repo redis
查看redis chart详情:helm show chart stable/redis
查看redis values(values:相当于chart的配置文件):helm show values stable/redis