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 ...
随机推荐
- L1-L11 jupter notebook 文件
L1-L11 jupter notebook 文件下载地址 https://download.csdn.net/download/xiuyu1860/12157961 包括L12 Transforme ...
- redis:key命令(二)
设置一个key:set name hello 获取一个key的值:get name 查看所有的key:keys * 查看key是否存在:exists name 移动key到指定库:move name ...
- JavaScript表达式和运算符 —— 基础语法(4)
JavaScript基础语法(4) 运算符 运算符用于将一 个或者多个值变成结果值. 使用运算符的值称为操作数,运算符和操作数的组合称为表达式 JS中的运算符可以分成下面几类: 算术运算符 逻辑运算符 ...
- python os模块判断文件是否存在
import os os.path.exists(test_file.txt)
- pytorch 中模型的保存与加载,增量训练
让模型接着上次保存好的模型训练,模型加载 #实例化模型.优化器.损失函数 model = MnistModel().to(config.device) optimizer = optim.Adam( ...
- jeecg ant design vue一级菜单跳到外部页面——例如跳到百度
需求:点击首页跳到百度新打开的页面 找到SideMenu.vue 对应的inde.js找到renderMenuItem 函数.加一个判断 if(menu.meta.url=='https://ww ...
- Python入门到进阶必看的权威书籍与网站
随着人工智能全面爆发,Python[英文单词:蟒蛇],是一款近年来爆红的计算机编程语言.1989年发明,1991年发行,比目前应用最广的Java还要大7岁,有种大器晚成的感觉. 分享之前我还是要推荐下 ...
- 你知道吗?iOS不少程序常传送装置信息给第三方
2019独角兽企业重金招聘Python工程师标准>>> 华盛顿邮报( The Washington Post)与隐私程序开发商Disconnect共同进行的研究揭露,许多iOS程序其 ...
- Yii项目Security加密解密类提取
<?php /** * @link http://www.yiiframework.com/ * @copyright Copyright (c) 2008 Yii Software LLC * ...
- Web全栈AngularJS
百度云盘下载 AngularJS是人类首个大规模使用的MVC框架,能够帮助程序员将绝大部分精力集中在核心业务逻辑上,从而大幅提高开发效率. 阶段2:Controller Controller是Angu ...