当前位置:首页 > 科技  > 软件

什么是Helm?它是如何提升云原生应用私有化部署效率的

来源: 责编: 时间:2024-01-08 09:16:16 370观看
导读大家好,我是蜗牛哥,试想一下,如果有一个项目有50 个微服务,每个微服务都有service、deployment、ingress、pvc等 yaml 文件,算下来大概有 200 个文件,然后这个项目需要基于k8s进行私有化交付,如果是你会怎么快速部署应用?首先

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

首先让我们先思考一下:Qkl28资讯网——每日最新资讯28at.com

  • 200 个文件是否通过kubectl apply进行部署,写个shell 脚本for 循环一个个读取执行?,但是如果这些yaml 文件更新了,如何同步?
  • 如果这些pod进行需要升级怎么办,一个个修改镜像 tag?
  • yaml文件关联地址如何更新,比如数据库地址、文件系统地址,日志目录,资源大小等?
  • 如果想进行卸载,如何做,一个个去删除?

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

Qkl28资讯网——每日最新资讯28at.com

什么是Helm

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

Qkl28资讯网——每日最新资讯28at.com

以下Helm中的概念:Qkl28资讯网——每日最新资讯28at.com

  • Helm Charts:预先配置yaml的模板,在这里叫Chart,用于描述 Kubernetes 应用程序的yaml和配置
  • Helm Client:用于与 Helm 交互并管理这些Chart版本的命令行界面
  • Chart 仓库:管理Chart的仓库,跟Maven的Nexus一个意思,比如在公司环境构建上传,在客户的机房连接到这Chart 仓库下载Chart,并部署到k8s中。

我们要做什么?

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

示例介绍

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

Qkl28资讯网——每日最新资讯28at.com

1.示例创建

我们通过helm create dp-manage命令创建一个Chart,执行完以后,默认会生成一个 nginx 的Chart,如下图Qkl28资讯网——每日最新资讯28at.com

Qkl28资讯网——每日最新资讯28at.com

2.关键文件说明

(1) Chart.yamlQkl28资讯网——每日最新资讯28at.com

定义了当前 chart版本,以及描述当前chart用途,其中 name 参数表示 chart 名称,后期上传下载都会用此名称Qkl28资讯网——每日最新资讯28at.com

Qkl28资讯网——每日最新资讯28at.com

(2) values.yamlQkl28资讯网——每日最新资讯28at.com

可变参数,都是在此文件中定义,在yaml模板中引用,比如:image.repository,而引用则通过.Values+变量的名进行引用,如下图Qkl28资讯网——每日最新资讯28at.com

Qkl28资讯网——每日最新资讯28at.com

Qkl28资讯网——每日最新资讯28at.com

(3) _helpers.tplQkl28资讯网——每日最新资讯28at.com

通用代码块定义,类似于freemaker的宏,然后在yaml中通过名称进行引用,include 修饰的都是,比如dp-manager.selectorLabelsQkl28资讯网——每日最新资讯28at.com

Qkl28资讯网——每日最新资讯28at.com

Qkl28资讯网——每日最新资讯28at.com

3.示例修改

由于默认创建一个Nginx 的 Chart 无法满足我们需求,所以删除掉多余的文件,并添加运维部署系统的yaml 文件,如下图:Qkl28资讯网——每日最新资讯28at.com

Qkl28资讯网——每日最新资讯28at.com

可以看到有8个模板文件,其中backend-dp.yaml定义如下:Qkl28资讯网——每日最新资讯28at.com

Qkl28资讯网——每日最新资讯28at.com

通过引用values.yml参数和_helpers.tpl的通用代码块,最终会生成一个k8s的deployment.yml文件,其他文件就不一一介绍Qkl28资讯网——每日最新资讯28at.com

构建与部署

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

Qkl28资讯网——每日最新资讯28at.com

1.关联仓库

在安装好 Helm client 以后,在本地执行以下命令,关联到仓库:Qkl28资讯网——每日最新资讯28at.com

helm repo add myrepo https://host/仓库地址 /--username sre /--password xxxx

添加完,执行helm repo list可以查到添加的myrepo仓库:Qkl28资讯网——每日最新资讯28at.com

Qkl28资讯网——每日最新资讯28at.com

2.构建打包

仓库关联好以后,执行helm package dp-manager命令打包,会生成一个dp-manager-1.0.0.tgz包:Qkl28资讯网——每日最新资讯28at.com

Qkl28资讯网——每日最新资讯28at.com

执行helm cm-push dp-manager-1.0.0.tgz myrepo推送至Harbor 仓库,myrepo为我们的仓库名称,推送完以后登录Harbor 查看,如下图:Qkl28资讯网——每日最新资讯28at.com

Qkl28资讯网——每日最新资讯28at.com

3.拉取部署

Chart 上传以后,我们在客户机房安装Helm Client和Kubectl客户端,具体安装方法查询网上,通过helm repo add关联Habor仓库地址,关联以后执行search 命令查找运维部署系统的Chart:Qkl28资讯网——每日最新资讯28at.com

helm search repo  myrepo/dp-manager

Qkl28资讯网——每日最新资讯28at.com

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

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 参数指定命名空间。Qkl28资讯网——每日最新资讯28at.com

命令执行完以后,可以通过helm list进行查看,如下图:Qkl28资讯网——每日最新资讯28at.com

helm list

Qkl28资讯网——每日最新资讯28at.com

4.更新

假设apollo.cluster值由 default修改为prod,执行upgrade 更新即可:Qkl28资讯网——每日最新资讯28at.com

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.卸载

卸载非常简单,执行以下命令即可:Qkl28资讯网——每日最新资讯28at.com

helm uninsall dp-manager

本文链接:http://www.28at.com/showinfo-26-57887-0.html什么是Helm?它是如何提升云原生应用私有化部署效率的

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 从错误中学习:了解 Go 编程的六个坏习惯

下一篇: Golang流水线设计模式实践

标签:
  • 热门焦点
  • 7月安卓手机好评榜:三星S23Ultra好评率第一

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年7月1日至7月31日,仅限国内市场。第一名:三星Galaxy S23 Ultra好评率:95.71%在即将迎来新
  • 6月安卓手机性价比榜:Note 12 Turbo断层式碾压

    6月份有一个618,虽然这是京东周年庆的日子,但别的电商也都不约而同的跟进了,反正促销没坏处,厂商和用户都能满意。618期间一些产品也出现了历史低价,那么各个价位段的产品性价比
  • Automa-通过连接块来自动化你的浏览器

    1、前言通过浏览器插件可实现自动化脚本的录制与编写,具有代表性的工具就是:Selenium IDE、Katalon Recorder,对于简单的业务来说可快速实现自动化的上手工作。Selenium IDEKat
  • 量化指标是与非:挽救被量化指标扼杀的技术团队

    作者 | 刘新翠整理 | 徐杰承本文整理自快狗打车技术总监刘新翠在WOT2023大会上的主题分享,更多精彩内容及现场PPT,请关注51CTO技术栈公众号,发消息【WOT2023PPT】即可直接领取
  • .NET 程序的 GDI 句柄泄露的再反思

    一、背景1. 讲故事上个月我写过一篇 如何洞察 C# 程序的 GDI 句柄泄露 文章,当时用的是 GDIView + WinDbg 把问题搞定,前者用来定位泄露资源,后者用来定位泄露代码,后面有朋友反
  • 一文搞定Java NIO,以及各种奇葩流

    大家好,我是哪吒。很多朋友问我,如何才能学好IO流,对各种流的概念,云里雾里的,不求甚解。用到的时候,现百度,功能虽然实现了,但是为什么用这个?不知道。更别说效率问题了~下次再遇到,
  • 认真聊聊东方甄选:如何告别低垂的果实

    来源:山核桃作者:财经无忌爆火一年后,俞敏洪和他的东方甄选依旧是颇受外界关心的“网红”。7月5日至9日,为期5天的东方甄选“甘肃行”首次在自有App内直播,
  • 疑似小米14外观设计图曝光:后置相机模组变化不大

    下半年的大幕已经开启,而谁将成为下半年手机圈的主角就成为了大家关注的焦点,其中被传有望拿下新一代骁龙8 Gen3旗舰芯片的小米14系列更是备受大家瞩
  • 引领旗舰级影像能力向中端机普及 OPPO K11 系列发布 1799 元起

    7月25日,OPPO正式发布K系列新品—— OPPO K11 。此次 K11 在中端手机市场长期被忽视的影像板块发力,突破性地搭载索尼 IMX890 旗舰大底主摄,支持 OIS
Top