053.集群管理-Helm部署及使用
一 Helm概述
1.1 Helm介绍
1.2 Helm优势
- 如何统一管理、配置和更新这些分散的 k8s 的应用资源文件;
- 如何分发和复用一套应用模板;
- 如何将应用的一系列资源当做一个软件包管理。
1.3 Helm 相关组件及概念
- helm:是一个命令行工具,主要用于 Kubernetes 应用程序 Chart 的创建、打包、发布以及创建和管理本地和远程的 Chart 仓库。
- Tiller:是 Helm 的服务端,部署在 Kubernetes 集群中。Tiller 负责接收 Helm 的请求,并根据 Chart 生成 Kubernetes 的部署文件( 称为 Release ),然后提交给 Kubernetes 创建应用。(v3版本已移除)
- chart:Helm 的打包格式叫做 chart,所谓 chart 就是一系列文件, 它描述了一组相关的 k8s 集群资源,即包含了一组定义 Kubernetes 资源相关的 YAML 文件。
- release:使用 helm install 命令在 Kubernetes 集群中部署的 Chart 称为 Release。
- Repoistory:Helm chart 的仓库,Repository 本质上是一个 Web 服务器,该服务器保存了一系列的 Chart 软件包以供用户下载,并且提供了一个该 Repository 的 Chart 包的清单文件以供查询。Helm 可以同时管理多个不同的 Repository。
二 Helm原理机制
2.1 Helm原理


2.2 Helm主要过程
- helm 客户端从指定的目录或本地tar文件或远程repo仓库解析出chart的结构信息;
- helm 客户端指定的 chart 结构和 values 信息通过 gRPC 传递给 Tiller;
- Tiller 服务端根据 chart 和 values 生成一个 release;
- Tiller 将install release请求直接传递给 kube-apiserver。
- helm 客户端从指定的目录或本地tar文件或远程repo仓库解析出chart的结构信息;
- helm 客户端指定的 chart 结构和 values 信息通过 gRPC 传递给 Tiller;
- Tiller 服务端根据 chart 和 values 生成一个 release;
- Tiller 将delete release请求直接传递给 kube-apiserver。
- helm 客户端将需要更新的 chart 的 release 名称、chart 结构和 value 信息传给 Tiller;
- Tiller 将收到的信息生成新的 release,并同时更新这个 release 的 history;
- Tiller 将新的 release 传递给 kube-apiserver 进行更新。
2.3 chart基本结构

- charts:该目录存放依赖的chart;
- Chart.yaml:包含Chart的基本信息,包括chart版本,名称等;
- templates:该目录下存放应用,即一系列 k8s 资源的 yaml 模板;
- _helpers.tpl:此文件中定义一些可重用的模板片断,此文件中的定义在任何资源定义模板中可用;
- NOTES.txt:介绍chart 部署后的帮助信息,如何使用chart等;
- values.yaml:包含了必要的值定义(默认值), 用于存储 templates 目录中模板文件中用到变量的值。
三 Helm部署安装
3.1 前置准备
- 正在运行的 Kubernetes 集群;
- 本地 Docker 客户端;
- 预配置的 kubectl 客户端和 Kubernetes 集群正确交互。
3.2 安装Helm
- 二进制安装
1 [root@master01 ~]# wget https://get.helm.sh/helm-v3.1.2-linux-amd64.tar.gz
2 [root@master01 ~]# tar -zxvf helm-v3.1.2-linux-amd64.tar.gz
3 [root@master01 ~]# cp linux-amd64/helm /usr/local/bin/
- 脚本安装
1 [root@master01 ~]# curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3
2 [root@master01 ~]# chmod 700 get_helm.sh
3 [root@master01 ~]# ./get_helm.sh
1 [root@master01 ~]# helm version #查看安装版本
2 [root@master01 ~]# echo 'source <(helm completion bash)' >> .bashrc #helm自动补全
四 Helm操作
4.1 查找chart
1 [root@master01 helm]# helm search hub #可搜索全部可用chart
2 [root@master01 helm]# helm search hub wordpress
4.2 添加repo
1 [root@master01 helm]# helm repo list #查看repo
2 [root@master01 helm]# helm repo add brigade https://brigadecore.github.io/charts
3 [root@master01 helm]# helm repo add stable https://kubernetes-charts.storage.googleapis.com/ #添加官方repo
4 [root@master01 helm]# helm repo add bitnami https://charts.bitnami.com/bitnami
5
6 [root@master01 helm]# helm search repo brigade
7 [root@master01 helm]# helm search repo stable #搜索repo中的chart
8 [root@master01 helm]# helm repo update #更新repo的chart
9 [root@master01 helm]# helm repo remove stable #移除repo
4.3 安装软件包
1 [root@master01 helm]# helm search repo mariadb #查找确认存在
2 [root@master01 helm]# helm show chart bitnami/mariadb #可提前查看相关信息
3 [root@master01 helm]# helm install xhy_mariadb bitnami/mariadb #以repo中chart安装
4 [root@master01 helm]# helm install xhy_mariadb2 bitnami.mariadb.tgz #以压缩包中chart安装
5 [root@master01 helm]# helm install xhy_mariadb3 mariadb/ #以解压后的目录安装
6 [root@master01 helm]# helm install xhy_mariadb4 https://hub.helm.sh/charts/bitnami/mariadb.tgz #以远程路径安装
7 [root@master01 helm]# helm ls #查看已安装的release
4.4 状态查看
1 [root@master01 ~]# helm status xhy-mariadb

4.5 升级回滚
1 [root@master01 helm]# vi mariadb.yml #以新配置重发布
2 rootUser:
3 password: abcd1234
4 [root@master01 helm]# helm upgrade -f mariadb.yml xhy-mariadb bitnami/mariadb #升级
5 [root@master01 helm]# helm get values xhy-mariadb #查看新配置

1 [root@master01 helm]# helm history xhy-mariadb #查看安装历史
2 [root@master01 helm]# helm rollback xhy-mariadb 1 #回滚

4.6 卸载release
1 [root@master01 helm]# helm uninstall xhy-mariadb #卸载release
2 [root@master01 helm]# helm list

4.7 其他常见选项
五 Helm自定义安装
5.1 查看chart默认value
1 [root@master01 ~]# helm show values bitnami/mariadb #查看此chart可自定义配置项
2 ……
3 rootUser:
4 ## MariaDB admin password
5 ## ref: https://github.com/bitnami/bitnami-docker-mariadb#setting-the-root-password-on-first-run
6 ##
7 password: ""
8 ……
5.2 传递配置方式
5.3 配置文件定义配置项
1 [root@master01 helm]# vi mariadb.yml #创建自定义配置
2 rootUser:
3 password: abcd1234
4
5.4 命令行定义配置项
1 [root@master01 helm]# helm install --set rootUser.password=abcd1234 xhy_mariadb bitnami/mariadb
|
命令行
|
yaml
|
|
--set name=value
|
name: value
|
|
--set a=b,c=d
|
a: b
c: d
|
|
--set outer.inner=value
|
outer:
inner: value
|
|
--set name={a, b, c}
|
name:
- a
- b
- c
|
|
--set servers[0].port=80
|
servers:
- port: 80
|
|
--set servers[0].port=80,servers[0].host=example
|
servers:
- port: 80
host: example
|
|
--set name=value1\,value2
|
name: "value1,value2"
|
|
--set nodeSelector."kubernetes\.io/role"=master
|
nodeSelector:
kubernetes.io/role: master
|
六 创建chart
6.1 创建chart命令
1 [root@master01 helm]# helm create test-chart

1 [root@master01 helm]# helm lint test-chart/ #验证创建后是否正常
2 [root@master01 helm]# helm package test-chart #将创建的进行打包
3 [root@master01 helm]# helm install test-chart/ ./test-chart/-0.1.0.tgz #安装
4
七 Monocular
7.1 Monocular介绍
7.2 Monocular安装
1 [root@master01 ~]# helm repo add monocular https://helm.github.io/monocular #添加repo
2 [root@master01 ~]# kubectl create ns helm
3 [root@master01 ~]# cat > custom-repos.yaml <<EOF
4 sync:
5 repos:
6 - name: stable
7 url: https://kubernetes-charts.storage.googleapis.com
8 schedule: "0 * * * *"
9 successfulJobsHistoryLimit: 1
10 - name: incubator
11 url: https://kubernetes-charts-incubator.storage.googleapis.com
12 schedule: "*/5 * * * *"
13 - name: monocular
14 url: https://helm.github.io/monocular
15 ui:
16 replicaCount: 2
17 service:
18 name: monocular-ui
19 type: NodePort
20 externalPort: 80
21 internalPort: 8080
22 annotations: {}
23 # foo.io/bar: "true"
24 ingress:
25 hosts:
26 - monocular.odocker.com
27 EOF #添加自定义配置:配置默认添加的repo及ingress host
28 [root@master01 ~]# helm install mymonocular monocular/monocular -f custom-repos.yaml -n helm
29
7.3 确认安装
1 [root@master01 ~]# kubectl get pods -n helm -o wide
2 [root@master01 ~]# kubectl get svc -n helm -o wide
3 [root@master01 ~]# kubectl get ingresses -n helm -o wide
4

八 helm部署WordPress
8.1 查看chart包
1 [root@master01 ~]# helm repo add bitnami https://charts.bitnami.com/bitnami
2 [root@master01 ~]# helm search repo wordpress
3 NAME CHART VERSION APP VERSION DESCRIPTION
4 bitnami/wordpress 9.2.4 5.4.1 Web publishing platform for building blogs and ...
5
8.2 安装WordPress
1 [root@master01 ~]# kubectl create ns wp
2 [root@master01 ~]# vi custom-wordpress.yaml
3 wordpressUsername: admin
4 wordpressPassword: admin12345
5 wordpressBlogName: Xhy Blog!
6 persistence:
7 enabled: true
8 storageClass: "ghsc"
9 accessMode: ReadWriteOnce
10 size: 5Gi
11
12
13 mariadb:
14 db:
15 name: wpdb
16 user: wpuser
17 password: wppass12345
18 rootUser: wpadmin
19 password: wpadminpass12345
20
21
22 master:
23 persistence:
24 enabled: true
25 storageClass: "ghsc"
26 accessModes:
27 - ReadWriteOnce
28 size: 5Gi
29
30
31 service:
32 type: NodePort
33 nodePorts:
34 http: "30005"
35 https: "30006"
36
1 [root@master01 ~]# helm install mywp bitnami/wordpress -f custom-wordpress.yaml -n wp
8.3 确认安装
1 [root@master02 ~]# kubectl get pods -n wp -o wide
2 [root@master02 ~]# kubectl get pv -n wp -o wide | grep wp
3 [root@master02 ~]# kubectl get pvc -n wp -o wide
4 [root@master02 ~]# kubectl get svc -n wp -o wide
8.4 访问测试
1 [root@master01 ~]# kubectl get --namespace wp -o jsonpath="{.spec.ports[0].nodePort}" services mywp-wordpress #查看端口
2 30005
3 [root@master01 ~]# kubectl get nodes --namespace wp -o jsonpath="{.items[0].status.addresses[0].address}" #查看node ip
4 172.24.8.71


053.集群管理-Helm部署及使用的更多相关文章
- Docker集群管理工具 - Kubernetes 部署记录 (运维小结)
一. Kubernetes 介绍 Kubernetes是一个全新的基于容器技术的分布式架构领先方案, 它是Google在2014年6月开源的一个容器集群管理系统,使用Go语言开发,Kubernete ...
- supervisor的安装部署及集群管理
supervisor的安装部署及集群管理 supervisor官网:http://www.supervisord.org/ 参考链接: http://blog.csdn.net/xyang81/art ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录
0.目录 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.感谢 在此感谢.net ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之集群部署环境规划(一)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.环境规划 软件 版本 ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之自签TLS证书及Etcd集群部署(二)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.服务器设置 1.把每一 ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之flanneld网络介绍及部署(三)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.flanneld介绍 ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之部署master/node节点组件(四)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 1.部署master组件 ...
- Kubernetes容器集群管理环境 - 完整部署(中篇)
接着Kubernetes容器集群管理环境 - 完整部署(上篇)继续往下部署: 八.部署master节点master节点的kube-apiserver.kube-scheduler 和 kube-con ...
- Kubernetes容器集群管理环境 - 完整部署(上篇)
Kubernetes(通常称为"K8S")是Google开源的容器集群管理系统.其设计目标是在主机集群之间提供一个能够自动化部署.可拓展.应用容器可运营的平台.Kubernetes ...
随机推荐
- Python 输出漂亮的表格的5个案例,实用方便
文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者:程序IT圈 PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行 ...
- C# 基础知识系列- 11 委托和事件
0. 前言 事件和委托是C#中的高级特性,也是C#中很有意思的一部分.出现事件的地方,必然有委托出现:而委托则不一定会有事件出现.那为什么会出现这样的关系呢?这就需要从事件和委托的定义出发,了解其中的 ...
- Obtain The String CodeForces - 1295C binary_search+思维
妈耶,,,被B题卡到哭,C题一发就过了... 字符串问题.首先用vector记录每个字符出现的位置,然后对字符串t的每个字符,用二分查找函数查找,注意用upper_bound查找,对于字符i,首先用变 ...
- 排序算法代码实现-Java
前言 为了准备面试,从2月开始将排序算法认认真真得刷了一遍,通过看书看视频,实践打代码,还有一部分的leetcode题,自己感觉也有点进步,将笔记记录总结发出来. 冒泡排序 该排序就是一种像泡泡浮到水 ...
- jmeter并发时生成唯一变量
vars.put("partnerOrderId","ZS"+Thread.currentThread().getId()+System.currentTime ...
- [YII2] Activeform表单部分组件使用方法
文本框:textInput(); 密码框:passwordInput(); 单选框:radio(),radioList(); 复选框:checkbox(),checkboxList(); 下拉框:dr ...
- 取代 Python 多进程!伯克利开源分布式框架 Ray
Ray 由伯克利开源,是一个用于并行计算和分布式 Python 开发的开源项目.本文将介绍如何使用 Ray 轻松构建可从笔记本电脑扩展到大型集群的应用程序. 并行和分布式计算是现代应用程序的主要内容. ...
- 如何使用IE9浏览器自带开发人员工具捕获网页请求
我们在通过浏览器访问一个网页的时候,有时候会遇到页面不能正常显示,图片不能正常加载的问题. 如果我们需要知道浏览器打开该网页时,网页中每个元素的加载情况.这时,我们便可以借助浏览器自带开发人员工具,来 ...
- ES6让字符串String增加了哪些好玩的特性呢?
确实因为现在天气变热了,所以一天天的这么写我也很累.所以如果阅读的时候有什么错误还请大家指出来,不好意思.学习永无止境. OK,今天继续讲解ES6系列知识 学过上一节的解构赋值就知道,ES6确实给我们 ...
- Python快速编程入门,打牢基础必须知道的11个知识点 !
Python被誉为全世界高效的编程语言,同时也被称作是“胶水语言”,那它为何能如此受欢迎,下面我们就来说说Python入门学习的必备11个知识点,也就是它为何能够如此受欢迎的原因. Python 简介 ...


