mac 上学习k8s系列helm chart

Posted golang算法架构leetcode技术php

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mac 上学习k8s系列helm chart相关的知识,希望对你有一定的参考价值。

类似php 的composer ,go 的go vendor ,linux 的yum ,helm是k8s 应用部署的管理工具。


在mac上如何使用呢?

brew install helm

需要注意的是 helm2 和hlm3 相比变化非常大

helm2 和k8s之间有一层代理tiller,但是从kubernetes 1.6开始默认开启RBAC。这是Kubernetes安全性/企业可用的一个重要特性。但是在RBAC开启的情况下管理及配置Tiller变的非常复杂。为了简化helm的尝试成本我们给出了一个不需要关注安全规则的默认配置。但是,这会导致一些用户意外获得了他们并不需要的权限。并且,管理员/SRE需要学习很多额外的知识才能将Tiller部署的到关注安全的生产环境的多租户K8S集群中并使其正常工作。


在了解了社区成员通常的使用场景后,我们发现Tiller的发布管理系统不需要依靠集群内的Operator来维护状态或充当Helm发布信息的中央枢纽。相反,我们可以简单地从Kubernetes API服务器中获取信息,渲染Charts客户端,并在Kubernetes中存储安装记录。


helm2 需要安装tiller

helm init --client-only --stable-repo-url https://aliacs-app-catalog.oss-cn-hangzhou.aliyuncs.com/charts/

helm3 已经移除了 init 命令


helm 管理的包,被称为chart,下面创建一个chart

%helm create mychart Creating mychart

看下chart里面有哪些东西呢?

% cd mychart% tree.|____Chart.yaml|____charts|____.helmignore|____templates| |____deployment.yaml| |____NOTES.txt| |____ingress.yaml| |____tests| | |____test-connection.yaml| |____service.yaml| |____hpa.yaml| |____serviceaccount.yaml| |_____helpers.tpl|____values.yaml

Templates 目录下 YAML 文件模板(go template语法)填充的值默认都是在 values.yaml 里定义的,比如在 deployment.yaml 中定义的容器镜像:

% cat mychart/values.yaml|grep repository repository: nginx

以上变量值是在 create chart 的时候就自动生成的默认值,你可以根据实际情况进行修改。


编写应用的介绍信息

 mychart/Chart.yaml

编写应用具体部署信息

编辑 mychart/values.yaml,它默认会在 Kubernetes 部署一个 Nginx。下面是 mychart 应用的 values.yaml 文件的内容


#检查依赖和模版配置是否正确

% helm lint mychart==> Linting mychart[ERROR] Chart.yaml: unable to parse YAML error converting YAML to JSON: yaml: line 27: could not find expected ':'[ERROR] templates/: cannot load Chart.yaml: error converting YAML to JSON: yaml: line 27: could not find expected ':'[ERROR] : unable to load chart cannot load Chart.yaml: error converting YAML to JSON: yaml: line 27: could not find expected ':'
Error: 1 chart(s) linted, 1 chart(s) failed
% helm lint mychart==> Linting mychart[INFO] Chart.yaml: icon is recommended
1 chart(s) linted, 0 chart(s) failed

打包应用

% helm package mychart //将应用打包Successfully packaged chart and saved it to: /Users/xiazemin/go/src/github.com/xiazemin/helm_learn/mychart-0.1.0.tgz

mychart 目录会被打包为一个 mychart-0.1.0.tgz 格式的压缩包,该压缩包会被放到当前目录下。

如果你想看到更详细的输出,可以加上 --debug 参数来查看打包的输出。

离线部署

注意: ~/.kube/config不存在的情况下要用 helm --kubeconfig 指定配置文件

# 方式一$ helm install demo-test ./mychart
# 可根据不同的配置来install,默认是values.yaml# helm install demo-test ./mychart -f ./mychart/values-prod.yaml
# 方式二$ helm install demo-test ./mychart-0.1.0.tgz
$ helm list
# 升级# $ helm upgrade demo-test ./mychart-0.2.0.tgz
helm install demo-test ./mychartNAME: demo-testLAST DEPLOYED: Sun Apr 4 16:53:14 2021NAMESPACE: defaultSTATUS: deployedREVISION: 1NOTES:1. Get the application URL by running these commands: export POD_NAME=$(kubectl get pods --namespace default -l "app.kubernetes.io/name=mychart,app.kubernetes.io/instance=demo-test" -o jsonpath="{.items[0].metadata.name}") export CONTAINER_PORT=$(kubectl get pod --namespace default $POD_NAME -o jsonpath="{.spec.containers[0].ports[0].containerPort}") echo "Visit http://127.0.0.1:8080 to use your application" kubectl --namespace default port-forward $POD_NAME 8080:$CONTAINER_PORT
% helm listNAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSIONdemo-test default 1 2021-04-04 16:53:14.890414 +0800 CST deployed mychart-0.1.0 1.16.0 

将应用发布到 Repository

harbor1.6+ 支持存储 helm charts,这里使用 helm 安装 harbor


这里为了简化测试操作,我关闭了数据卷的挂载并使用的是 NodePort 方式进行访问。

https://github.com/goharbor/harbor/

以上是关于mac 上学习k8s系列helm chart的主要内容,如果未能解决你的问题,请参考以下文章

26,k8s 之helm

K8S集群中使用Helm管理应用分发

Kubernetes 与 Helm:使用同一个 Chart 部署多个应用

k8s的Helm

k8s学习-Helm

k8s学习-Helm