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 ...
随机推荐
- Hash记录字符串
Hash记录字符串模板: mod常常取1e9+7,base常常取299,,127等等等....有的题目会卡Hash,因为可能会有两个不同的Hash但却有相通的Hash值...这个时候可以用双Hash来 ...
- B - Cow Marathon DFS+vector存图
After hearing about the epidemic of obesity in the USA, Farmer John wants his cows to get more exerc ...
- C#开发BIMFACE系列34 服务端API之模型对比5:获取模型构件对比差异
系列目录 [已更新最新开发文章,点击查看详细] BIMFACE平台提供了服务端“获取修改构件属性差异”API,其返回的结果也是一个列表,仅针对修改的构件(不包含新增.删除的构件),是指对于一个 ...
- Unity 游戏框架搭建 2019 (三十、三十一) MenuItem 显示顺序问题 & 类的提取
在上一篇,我们得出了两个核心的学习思路: 根据问题去学习,并收集. 主动学习,并思考适用场景. 我们今天解决 MenuItem 显示顺序问题. 目前 MenuItem 显示如图所示: 我们来看下 Me ...
- phpMyAdmin后台文件包含溯源
先上大佬解释的漏洞原理链接 https://mp.weixin.qq.com/s?__biz=MzIzMTc1MjExOQ==&mid=2247485036&idx=1&sn= ...
- C#多线程(12):线程池
目录 线程池 ThreadPool 常用属性和方法 线程池说明和示例 线程池线程数 线程池线程数说明 不支持的线程池异步委托 任务取消功能 计时器 线程池 线程池全称为托管线程池,线程池受 .NET ...
- ASP.NET Core Razor Pages 初探
最近新建 Asp.net Core MVC 项目的时候不小心选错了个模板,发现了一种新的项目模板.它使用cshtml视图模板,但是没有Controller文件夹.后来才发现这是ASP.NET Core ...
- 批量查询PDF文本并导出结果的小工具
效果: 批量查询指定关键字 & 指定目录下PDF文件中的文本,并导出文件路径和关键字所在文本行. 下载: 链接: https://pan.baidu.com/s/1sK2OMMgGX26l7P ...
- [Qt] 通过socket将另一个程序的某个窗口调到最前端
@ // THIS IS A HACK: // from QT documentation: // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ...
- Jetson AGX Xavier刷机
1. 准备一台电脑做主机(host),运行Ubuntu系统,我用的是虚拟机,运行的是Ubuntu 18.04系统. 2. 主机更换apt-get源,参见https://www.cnblogs.com/ ...


