目录
Helm
Helm 的安装
Helm Chart 的创建
Helm 的使用
极狐GitLab Helm Registry 使用
上传 Helm Chart 到极狐GitLab Helm Registry
使用极狐GitLab Helm Registry Chart
Helm 是 Kubernetes 的包管理工具,是发现、分享以及使用那些在 Kubernetes 上构建的软件的最好方法。目前是 3.9.0
版本。
Helm 的安装非常简单,可以通过命令行来安装,诸如 brew
、scoop
、gofish
、snap
等方式来安装,也可以通过下载二进制文件包并将其添加到 PATH 中即可,本文选择用通过下载二进制文件包来安装。
在 release页面找到需要安装的版本,直接下载即可。以 macOS 为例,用如下命令完成下载:
$ wget https://get.helm.sh/helm-v3.9.0-darwin-amd64.tar.gz
然后解压并将解压后的二进制文件添加到 PATH 中:
$ tar -zxvf helm-v3.9.0-darwin-amd64.tar.gz
x darwin-amd64/
x darwin-amd64/helm
x darwin-amd64/LICENSE
x darwin-amd64/README.md
$ mv darwin-amd64/helm /usr/local/bin/helm
然后使用 version
或者 --help
来查看是否安装成功:
$ helm version
version.BuildInfo{Version:"v3.9.0", GitCommit:"7ceeda6c585217a19a1131663d8cd1f7d641b2a7", GitTreeState:"clean", GoVersion:"go1.17.5"}
使用 create
命令即可创建一个 helm chart
$ helm create devops-is-shit
Creating devops-is-shit
chart 的目录结构如下:
$ tree
.
├── Chart.yaml
├── charts
├── templates
│ ├── NOTES.txt
│ ├── _helpers.tpl
│ ├── deployment.yaml
│ ├── hpa.yaml
│ ├── ingress.yaml
│ ├── service.yaml
│ ├── serviceaccount.yaml
│ └── tests
│ └── test-connection.yaml
└── values.yaml
helm create devops-is-shit
Creating devops-is-shit
修改 values.yaml
文件,写入镜像、资源限制等基本内容,即可完成一个简单的 helm chart demo。接着用 helm install
命令进行安装测试。
$ helm install jihu --namespace jihu --create-namespace -f values.yaml .
NAME: jihu
LAST DEPLOYED: Wed Jul 6 09:04:16 2022
NAMESPACE: jihu
STATUS: deployed
REVISION: 1
NOTES:
1. Get the application URL by running these commands:
export POD_NAME=$(kubectl get pods --namespace jihu -l "app.kubernetes.io/name=devops-is-shit,app.kubernetes.io/instance=jihu" -o jsonpath="{.items[0].metadata.name}")
export CONTAINER_PORT=$(kubectl get pod --namespace jihu $POD_NAME -o jsonpath="{.spec.containers[0].ports[0].containerPort}")
echo "Visit http://127.0.0.1:8080 to use your application"
kubectl --namespace jihu port-forward $POD_NAME 8080:$CONTAINER_PORT
可以查看一下生成的 deployment
、pod
、service
资源:
$ kubectl -n jihu get deploy,pods,svc
NAME READY UP-TO-DATE AVAILABLE AGE
deployment.apps/jihu-devops-is-shit 1/1 1 1 2d5h
NAME READY STATUS RESTARTS AGE
pod/jihu-devops-is-shit-6d5c8cdcf8-mffxz 1/1 Running 0 45s
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/jihu-devops-is-shit ClusterIP 10.107.177.80 80/TCP 2d5h
接着将 helm chart 打成一个 package:
$ helm package devops-is-shit
Successfully packaged chart and saved it to: /Users/xiaomage/Documents/xiaomage/helm-demo/devops-is-shit-0.1.0.tgz
$ ls -ltr
total 8
drwxr-xr-x 7 xiaomage staff 224 Jul 8 14:14 devops-is-shit
-rw-r--r-- 1 xiaomage staff 3554 Jul 8 14:14 devops-is-shit-0.1.0.tgz
接着将上面生成的 helm chart package 上传到极狐GitLab Helm Registry。关于极狐GitLab Helm Registry 使用的详细内容,可以查看极狐GitLab 官方文档。
使用如下命令即可将上述 package 上传到极狐GitLab Helm Registry:
$ curl --request POST \
--form '[email protected]' \
--user : \
https://gitlab.example.com/api/v4/projects//packages/helm/api//charts
参数说明:
传入实际参数后执行命令:
$ curl --request POST \
--form '[email protected]' \
--user keyboard-man:YOUR-JIHU-ACCESS-TOKEN \
https://jihulab.com/api/v4/projects/19649/packages/helm/api/test/charts
返回结果如下:
{"message":"201 Created"}
可以在极狐GitLab 界面上查看:项目 --> 软件包与镜像库 --> 软件包库
可以查看点击详情:
首先需要添加极狐GitLab Helm repo:
$ helm repo add --username --password project-1 https://gitlab.example.com/api/v4/projects//packages/helm/
传入实际参数并执行命令:
$ helm repo add --username keyboard-man --password YOUR-JIHU-ACCESS-TOKEN jihu-helm https://jihulab.com/api/v4/projects/19649/packages/helm/test
"jihu-helm" has been added to your repositories
查看 repo 是否添加成功:
$ helm repo list
NAME URL
jihu-helm https://jihulab.com/api/v4/projects/19649/packages/helm/test
可以看到已经添加成功,接着就可以使用了。用下面命令即可使用上述 helm chart 来安装一个 release:
$ helm install jihu-helm --namespace jihu-helm --create-namespace jihu-helm/devops-is-shit
NAME: jihu-helm
LAST DEPLOYED: Fri Jul 8 14:47:35 2022
NAMESPACE: jihu-helm
STATUS: deployed
REVISION: 1
NOTES:
1. Get the application URL by running these commands:
export POD_NAME=$(kubectl get pods --namespace jihu-helm -l "app.kubernetes.io/name=devops-is-shit,app.kubernetes.io/instance=jihu-helm" -o jsonpath="{.items[0].metadata.name}")
export CONTAINER_PORT=$(kubectl get pod --namespace jihu-helm $POD_NAME -o jsonpath="{.spec.containers[0].ports[0].containerPort}")
echo "Visit http://127.0.0.1:8080 to use your application"
kubectl --namespace jihu-helm port-forward $POD_NAME 8080:$CONTAINER_PORT
查看生成的资源:
$ kubectl -n jihu-helm get deploy,pods,svc
NAME READY UP-TO-DATE AVAILABLE AGE
deployment.apps/jihu-helm-devops-is-shit 1/1 1 1 97s
NAME READY STATUS RESTARTS AGE
pod/jihu-helm-devops-is-shit-6d847f6489-c79zm 1/1 Running 0 97s
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/jihu-helm-devops-is-shit ClusterIP 10.98.248.103 80/TCP 97s
可以看到成功创建了 pod
。
可以看到极狐GitLab Helm Registry 的使用还是非常方便的,下一篇内容将讲述如何将极狐GitLab Helm Registry 的使用和极狐GitLab CI/CD 结合起来。