什么是Helm?它是如何提升树叶云应用私有化部署效率的 (什么是合力)

技术教程 2025-05-10 21:53:57 浏览

大家好,我是蜗牛哥,试想一下,如果有一个项目有50 个微服务,每个微服务都有service、deployment、ingress、pvc等 yaml 文件,算下来大概有 200 个文件,然后这个项目需要基于k8s进行私有化交付,如果是你会怎么快速部署应用?

首先让我们先思考一下:

如果有一个工具能把这些yaml文件放在一个包里,类似npm、maven这样的包管理工具,然后把关键的参数暴露出来,在部署时指定这些参数,执行一键部署,在卸载时一键卸载是不是很方便,而Helm 就是这样的工具。

什么是Helm

Helm 是一个能够在 Kubernetes 上打包、部署和管理应用程序的工具,即使是最复杂的 Kubernetes 应用程序它都可以帮助定义,安装和升级,同时Helm 也是CNCF的毕业项目。

以下Helm中的概念:

我们要做什么?

这里我们不介绍Helm 的具体函数,具体可以查官网,这里只讲一下如何使用Helm,让你对Helm有一个认识,知道在什么场景下使用即可,所以我们结合一个示例讲一下玩法。

示例介绍

有一个运维部署系统,分为前后端,需要部署到客户机房,在k8s架构如下,可以看到需要8 个文件(其中Istio需要2个yaml文件),下面通过示例一步步创建这个Chart。

1.示例创建

我们通过helm CREATE dp-manage命令创建一个Chart,执行完以后,默认会生成一个 Nginx 的Chart,如下图

2.关键文件说明

(1) Chart.yaml

定义了当前 chart版本,以及描述当前chart用途,其中 name 参数表示 chart 名称,后期上传下载都会用此名称

(2) values.yaml

可变参数,都是在此文件中定义,在yaml模板中引用,比如:image.repository,而引用则通过.Values+变量的名进行引用,如下图

(3) _helpers.tpl

通用代码块定义,类似于freemaker的宏,然后在yaml中通过名称进行引用,include修饰的都是,比如dp-Manager.selectorLabels

3.示例修改

由于默认创建一个Nginx 的 Chart 无法满足我们需求,所以删除掉多余的文件,并添加运维部署系统的yaml 文件,如下图:

可以看到有8个模板文件,其中backend-dp.yaml定义如下:

通过引用values.yml参数和_helpers.tpl的通用代码块,最终会生成一个k8s的deployment.yml文件,其他文件就不一一介绍

构建与部署

通过前面的介绍,需要把Chart构建好以后,上传到Chart仓库,然后在客户机房连接这个仓库,进行下载,因此需要一个Chart 仓库,这里我们使用Harbor ,Habor可以作为容器镜像仓库也可以作为 Chart仓库一举两得,推荐使用。

1.关联仓库

在安装好 Helm client 以后,在本地执行以下命令,关联到仓库:

helm repo add myrepo仓库地址 \--username sre \--password xxxx

添加完,执行helm repo list可以查到添加的myrepo仓库:

2.构建打包

仓库关联好以后,执行helm package dp-manager命令打包,会生成一个dp-manager-1.0.0.tgz包:

执行helm cm-push dp-manager-1.0.0.tgz myrepo推送至Harbor 仓库,myrepo为我们的仓库名称,推送完以后登录Harbor 查看,如下图:

3.拉取部署

Chart 上传以后,我们在客户机房安装Helm Client和Kubectl客户端,具体安装方法查询网上,通过helm repo add关联Habor仓库地址,关联以后执行Search 命令查找运维部署系统的Chart:

helm search repomyrepo/dp-manager
什么是合力

Chart查询到以后,就可以进行部署了,部署分为两种方式,一种是下载 Chart至本地,修改values.yaml文件在部署,另外一种是不用下载直接指定参数部署,我们使用第二种:

helm install dp-manager myrepo/dp-manager\--set istioGateway.hosts={dpmanager.test.com} \--set pv.log.pvEnabled=false \--set pv.log.type=storageClass \--set pv.log.pvc.storageName=gfs-storage \--set pv.log.pvc.storage=20Gi \--set apollo.cluster=default 

我们在这个命令中指定了域名,存储大小等参数,这些参数通过values.yaml文件暴露,另外此命令部署运维部署系统至default命令空间,可以通过-n参数指定命名空间。

命令执行完以后,可以通过helm list进行查看,如下图:

4.更新

假设apollo.cluster值由 default修改为prod,执行upgrade更新即可:

helm upgrade dp-manager myrepo/dp-manager\--set istioGateway.hosts={dpmanager.test.com} \--set pv.log.pvEnabled=false \--set pv.log.type=storageClass \--set pv.log.pvc.storageName=gfs-storage \--set pv.log.pvc.storage=20Gi \--set apollo.cluster=prod 

5.卸载

卸载非常简单,执行以下命令即可:

什么是Helm
helm uninsall dp-manager

1.电压E越高,电泳速率v越快,反之则越慢。 (Helmholz方程) 2.胶体浓度越大,胶体的介电常数ε和粘度η也越大,前者有利于电泳速率增大而后者不利于 3. 环境温度较高,电流热效应越大(电压越高,通电时间越长),电泳速率较慢 4. 电极间距对电泳速率也有较大的影响。 这可从电泳的速率公式看出。 5. 胶体的是否纯化过 如果辅助液(这里是稀盐酸)的电导率于溶胶的电导率相差较大,则在整个电泳管内的电位降是不均匀的 这时就不能用H=U/L求电位梯度平均值

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐