简化Kubernetes应用部署工具-Helm简介
微服务和容器化给复杂应用部署与管理带来了极大的挑战。Helm是目前Kubernetes服务编排领域的唯一开源子项目,做为Kubernetes应用的一个包管理工具,可理解为Kubernetes的apt-get / yum,由Deis 公司发起,该公司已经被微软收购。Helm通过软件打包的形式,支持发布的版本管理和控制,很大程度上简化了Kubernetes应用部署和管理的复杂性。
随着业务容器化与向微服务架构转变,通过分解巨大的单体应用为多个服务的方式,分解了单体应用的复杂性,使每个微服务都可以独立部署和扩展,实现了敏捷开发和快速迭代和部署。但任何事情都有两面性,虽然微服务给我们带来了很多便利,但由于应用被拆分成多个组件,导致服务数量大幅增加,对于Kubernetest编排来说,每个组件有自己的资源文件,并且可以独立的部署与伸缩,这给采用Kubernetes做应用编排带来了诸多挑战:
管理、编辑与更新大量的Kubernetes配置文件
部署一个含有大量配置文件的复杂Kubernetes应用
分享和复用Kubernetes配置和应用
参数化配置模板支持多个环境
管理应用的发布:回滚、diff和查看发布历史
控制一个部署周期中的某一些环节
发布后的验证
而Helm恰好可以帮助我们解决上面问题。
Helm把Kubernetes资源(比如deployments、services或 ingress等)打包到一个chart中,而chart被保存到chart仓库。通过chart仓库可用来存储和分享chart。Helm使发布可配置,支持发布应用配置的版本管理,简化了Kubernetes部署应用的版本控制、打包、发布、删除、更新等操作。
本文简单介绍了Helm的用途、架构与实现。
Helm产生原因
利用Kubernetes部署一个应用,需要Kubernetes原生资源文件如deployment、replicationcontroller、service或pod 等。而对于一个复杂的应用,会有很多类似上面的资源描述文件,如果有更新或回滚应用的需求,可能要修改和维护所涉及的大量资源文件,且由于缺少对发布过的应用版本管理和控制,使Kubernetes上的应用维护和更新等面临诸多的挑战,而Helm可以帮我们解决这些问题。
Helm架构
Helm基本架构如下:
Helm用途
做为Kubernetes的一个包管理工具,Helm具有如下功能:
创建新的chart
chart打包成tgz格式
上传chart到chart仓库或从仓库中下载chart
在Kubernetes集群中安装或卸载chart
管理用Helm安装的chart的发布周期
Helm有三个重要概念:
chart:包含了创建Kubernetes的一个应用实例的必要信息
config:包含了应用发布配置信息
release:是一个chart及其配置的一个运行实例
Helm组件
Helm有以下两个组成部分:
Helm Client是用户命令行工具,其主要负责如下:
本地chart开发
仓库管理
与Tiller sever交互
发送预安装的chart
查询release信息
要求升级或卸载已存在的release
Tiller Server是一个部署在Kubernetes集群内部的server,其与Helm client、Kubernetes API server进行交互。
Tiller server主要负责如下:
监听来自Helm client的请求
通过chart及其配置构建一次发布
安装chart到Kubernetes集群,并跟踪随后的发布
通过与Kubernetes交互升级或卸载chart
简单的说,client管理charts,而server管理发布release。
Helm实现
Helm client
Helm client采用go语言编写,采用gRPC协议与Tiller server交互。
Helm server
Tiller server也同样采用go语言编写,提供了gRPC server与client进行交互,利用Kubernetes client 库与Kubernetes进行通信,当前库使用了REST+JSON格式。
Tiller server 没有自己的数据库,目前使用Kubernetes的ConfigMaps存储相关信息。
说明:配置文件尽可能使用YAM格式。
Spring Cloud实战训练营
本次培训内容包括:微服务架构及概述、微服务架构项目实战目标、Spring Boot概述、Spring Cloud简介与入门、Eureka、Ribbon、Feign、Hystrix、Zuul、Spring Cloud Config、Spring Cloud Sleuth等,点击识别下方二维码加微信好友了解具体培训内容。
点击阅读原文链接即可报名。
简化Kubernetes应用部署工具-Helm简介相关推荐
- 利用Helm简化Kubernetes应用部署(1)
目录 利用Helm简化Kubernetes应用部署 Helm基础 安装Helm 使用Visual Studio 2019为Helm编写一个简单的应用 利用Helm简化Kubernetes应用部 ...
- 利用Helm简化Kubernetes应用部署(2)
目录 定义Charts 使用Helm部署Demo Helm常用操作命令 定义Charts 回到之前的"charts"目录,我们依次进行解读并进行简单的修改. Chart.ya ...
- Kubernetes CRD开发工具Operator-SDK简介
原文连接:https://blog.csdn.net/weixin_33918114/article/details/92211707 概览 原文来自:https://github.com/opera ...
- 持续集成部署工具jenkins简介
1. Jenkins基本介绍 Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能.现在企业一般使用 ...
- 2021 年 Kubernetes 的开发者工具:Helm、Kustomize 和 Skaffold
在过去的几年里,我们已经看到在 Kubernetes 生态中出现了大量工具实现更简单的软件开发(这是非常难得的).正如经常发生在不断发展的生态系统中的那样,一些工具会不断发展并适应,而另一些工具则会被 ...
- Kubernetes K8S之通过helm部署metrics-server与HPA详解
Kubernetes K8S之通过helm部署metrics-server与 Horizontal Pod Autoscaling (HPA)详解 主机配置规划 服务器名称(hostname) 系统版 ...
- kubernetes:部署kubeapps应用,为Helm提供web UI界面管理
kubernetes 部署kubeapps应用,为Helm提供web UI界面管理 部署kubeapps应用,为Helm提供web UI界面管理 [kubeadm@server2 ~]$ helm r ...
- Kubernetes — Kubespray 开箱即用的部署工具
目录 文章目录 目录 Kubespray Kubespray 官网:https://kubespray.io 项目地址:https://github.com/kubernetes-sigs/kubes ...
- 在Kubernetes上部署和管理PostgreSQL
目录 有哪些选项可用于部署PostgreSQL? 选项 01 - 从头开始创建部署配置 选项 02 - 使用helm chart 什么是Helm? Helm架构 Helm由三个主要概念组成 如何安 ...
最新文章
- 高德地图markevents_GitHub - mingxuWang/Map: 高德地图API二次封装
- 【细品架构12/100】架构漫谈系列脑图
- BCH链上交易量翻5倍的背后隐藏着哪些秘密?
- 5月15日直播预告:英飞凌AURIX™培训—图像处理、实车演示等热点问题
- Windows Server 2008中部署AD
- java易语言_java程序员,0基础学习开发易语言。
- 开源免费,zabbix服务器监控全面实现
- AIX进程监控与管理
- python123文件和数据格式化测试7_二级Python----文件和数据格式化(DAY 7)
- Java集合之TreeMap源码解析上篇
- netperf使用指南
- 3.5!——阶乘的插值(python)
- JQuery 四个常用的DOM操作获得内容 - text()、html()、value 以及 val() ;取属性值attr()----前三个有回调函数
- centos7 redis配置
- 记录解决Mac系统升级后三指取词、词典失效问题的过程
- 球面坐标系与三角函数 Spherical Coordinates and Trigonometric Functions
- 三种加快计算机启动速度的办法,如何提高开机速度 几种提高开机速度的方法【图文】...
- java 防止超卖_实现防止超卖的几种方式
- 外发光材质Shader
- 从非洲血库到热带雨林:为什么普惠联接是社会的数字化支点?