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 ...
随机推荐
- Oracle使用fy_recover_data恢复truncate删除的数据
(一)truncate操作概述 在生产中,truncate是使用的多的命令,在使用不当的情况下,往往会造成表的数据全部丢失,恢复较为困难.对于truncate恢复,常见的有以下几种方法可以进行恢复: ...
- Pytorch实现MNIST手写数字识别
Pytorch是热门的深度学习框架之一,通过经典的MNIST 数据集进行快速的pytorch入门. 导入库 from torchvision.datasets import MNIST from to ...
- Java中Character类
Character 类在对象中包装一个基本类型char的值此外,该类提供了几种方法,以确定字符的类别(小写字母,数字,等),并将字符从大写转小写,反之亦然. 构造方法: Character(char ...
- TensorFlow的图像NCHW与NHWC
import tensorflow as tf x = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12] with tf.Session() as sess: a = t ...
- Zabbix3.4安装部署
Zabbix3.4安装部署 一.系统环境 cat /etc/redhat-release CentOS Linux release 7.3.1611 (Core) 关闭防火墙及selinux sy ...
- 日志分析工具ELK(四)
Logstash收集TCP日志 #Input plugins TCP插件 所需的配置选项 tcp { port =>... } [root@linux-node1 ~]# cat tcp.con ...
- java基础问题 (待解决)
(1)接口与抽象类的区别? (2)Java中的异常有哪几类?分别怎么使用? (3)常用的集合类有哪些?比如List如何排序? (4)ArrayList和LinkedList内部的实现大致是怎样的?他们 ...
- vue与众不同的学习方式,让她年薪200多万
学习vue正确思路,是先学vue-cli,再学vue.js单文件引用的用法,这样会在极短时间内撤底撑握vue,如果先学vue.js单文件用法,再去学vue-cli4,可以说是重新学vue,,,,难处大 ...
- HTML JavaScript 基础(下)
一.JavaScript 函数 1.普通函数-有函数名 function func(){ } 2.匿名函数-无函数名 setInterval(function(){ console.log(123); ...
- 《Java 开发从入门到精通》—— 2.3 使用IDE工具序
本节书摘来异步社区<Java 开发从入门到精通>一书中的第2章,第2.3节,作者: 扶松柏 , 陈小玉,更多章节内容可以访问云栖社区"异步社区"公众号查看. 2.3 使 ...