既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
Kubernetes使用yaml文件来描述和管理服务中各个组件的配置和部署需求,每个组件对应一个yaml文件。云服务通常都是由多个组件构成的,如何配置和处理好这些组件即多个yaml文件之间的关联关系,成为了Kubernetes应用的必须面对的。
当云服务升级只涉及其中一个或某几个模块时,升级模块的新yaml文件和已有yaml文件之间的关联关系会变得更加复杂,增加了使用Kubernetes来配置和管理升级的难度。
另外,Kubernetes把组件的配置信息也直接记录到yaml文件当中。从描述组件的角度来讲,这种方式确实比较清晰。但是,当云服务的部署面对多个环境,如不同的开发、测试、产品环境(当前比较常见的应用场景),要如何处理这些环境配置之间的差别呢?为每个环境都开发和维护一套不同的yaml文件?这显然增加了许多工作量。
并且,Kubernetes的yaml文件本身是没有版本的概念的。当某次部署失败,需要回滚到上一个稳定版本,该选择哪一套yaml文件来处理也成了需要解决的额外问题。
所以,Helm可以很好的解决这些问题。Helm是通过被称作Helm Chart的包来描述和管理云服务的。
以一敌百:深入了解Helm架构
Helm的架构由Helm客户端、Tiller服务器端和Chart仓库所组成;Tiller部署在Kubernetes中,Helm客户端从Chart仓库中获取Chart安装包,并将其安装部署到Kubernetes集群中。
1、Helm客户端
Helm客户端:这是一个供终端用户使用的命令行工具,客户端负责如下的工作:
- 本地chart开发、管理仓库
- 与Tiller服务器交互,如:发送需要被安装的charts、请求关于发布版本的信息、请求更新或者卸载已安装的发布版本
Helm客户端是使用Go语言编写的,它通过gRPC协议与Tiller服务器交互。
2、Tiller服务器
Tiller服务部署在Kubernetes集群中,Helm客户端通过与Tiller服务器进行交互,并最终与Kubernetes API服务器进行交互。 Tiller服务器负责如下的工作:
- 监听来自于Helm客户端的请求
- 组合chart和配置来构建一个发布
- 在Kubernetes中安装,并跟踪后续的发布
- 通过与Kubernetes交互,更新或者chart
Tiller服务器也是使用Go语言编写的,它使用Kubernetes客户端类库与Kubernetes进行通讯。
3、chart
先简单创建个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
- Chart.yaml 用于描述这个 Chart的相关信息,包括名字、描述信息以及版本等。
- values.yaml 用于存储 templates 目录中模板文件中用到变量的值。
- NOTES.txt 用于介绍 Chart 部署后的一些信息,例如:如何使用这个 Chart、列出
核心概念:Helm的三大法宝
在上面的功能中,有三个重要概念要理解:
- chart:创建Kubernetes应用实例的信息集合,helm package,包含一个k8s app应用运行起来的所有要素,比如service, deployment, configmap, serviceaccount, rbac等,这些都是以template文件的形式存在,再结合values文件,最终渲染出能够被k8s执行的yaml文件;
- repository:是charts的集合,方便进行分享和分发。
- release:release是helm chart在kubernetes的一个运行实例,可以用不同的release name多次安装同一个chart,比如:当集群中需要多个redis实例,可以使用不同的配置文件安装redis chart。
那么,helm的运行流程如下:
首先,从chart仓库中获取chart,然后开发者配置自己的values文件,根据自己的运行环境对values进行修改,然后默认values文件和使用者values文件会进行一个merge,形成最终的values文件;使用最终的values文件,渲染chart的template,形成可以被kubernetes执行的yaml,最后调用kube apply提交yaml到kubernetes。
在上述的过程中,使用者只需要理解一点点配置的知识就可以完成操作,没有那么困难了。这也正是helm的核心设计理念。
如日中天:实战Helm Demo
- 1、安装helm
curl https://baltocdn.com/helm/signing.asc | sudo apt-key add –


**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.youkuaiyun.com/topics/618545628)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
//bbs.youkuaiyun.com/topics/618545628)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**