【Helm 及 Chart 快速入门】02、Helm 基本使用
目录
?
一、Helm 基本使?
1.1 搜索 chart 应??
使? helm search repo 关键字可以查看相关 charts:
[root@k8s-master1 ~]# helm search repo nginx
[root@k8s-master1 ~]# helm search repo mariadb
1.2?部署 chart 应??
????????部署?个 MySQL 5.7 的应?(需要提前部署动态存储, nfs-provisionerstorage,参考文章 【云原生 | Kubernetes 实战】13、K8s 常见的存储方案及具体应用场景分析(下)-CSDN博客):
helm install stable/mysql --generate-name \
--set persistence.storageClass="nfs" \
--set mysqlRootPassword=Qwe123456 \
--set livenessProbe.initialDelaySeconds=150 \
--set readinessProbe.initialDelaySeconds=150 \
--namespace default
????????由于我们的 Kubernetes 节点硬件配置较差,MySQL 数据库启动的时间相对较 。为了防?在数据库还未完全启动成功,探针就开始进?健康检查,从?造成数据库检测失败?导致重启,我们将 initialDelaySeconds 设置为 150 秒。这 样可以确保数据库有?够的时间来完成启动过程,从?确保数据库能够正常运?。
-
livenessProbe:?来检查容器是否还在运?,如果 livenessProbe 失败, Kubernetes 会杀死容器。
-
readinessProbe:?来检查容器是否准备好对外提供服务。只有当 Pod 中所有容器的readinessProbe 都成功时 。
检查部署的应?:
[root@k8s-master1 ~]# kubectl get pod -o wide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
busybox 1/1 Running 24 (56m ago) 24h 10.244.169.130 k8s-node2 <none> <none>
mysql-1704769258-b9db9dcd9-hv9gs 1/1 Running 0 3m23s 10.244.169.131 k8s-node2 <none> <none>
nfs-provisioner-564c9cfbf6-j8dwn 1/1 Running 0 20m 10.244.36.65 k8s-node1 <none> <none>
访问数据库验证是否部署成功(提前准备好 mysql 客户端):
[root@k8s-master1 ~]# mysql -h 10.244.169.131 -uroot -pQwe123456
1.3 删除 chart 应?
????????如果需要删除刚才部署的 mysql release ,可以通过 helm uninstall 命令,也可以在卸载时指定 --keep-history 参数,这样后期还可以回滚:
[root@k8s-master1 ~]# helm ls
NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION
mysql-1704769258 default 1 2024-01-09 11:01:01.805963829 +0800 CST deployed mysql-1.6.9 5.7.30
# 使? --keep-history 记录 REVISON
[root@k8s-master1 ~]# helm uninstall mysql-1704769258 --keep-history
release "mysql-1704769258" uninstalled
# 查看历史记录
[root@k8s-master1 ~]# helm history mysql-1704769258
REVISION UPDATED STATUS CHART APP VERSION DESCRIPTION
1 Tue Jan 9 11:01:01 2024 uninstalled mysql-1.6.9 5.7.30 Uninstallation complete
[root@k8s-master1 ~]# helm ls
NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION
# 使? rollback 撤销删除操作(回滚)
[root@k8s-master1 ~]# helm rollback mysql-1704769258 1
Rollback was a success! Happy Helming!
[root@k8s-master1 ~]# helm ls
NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION
mysql-1704769258 default 2 2024-01-09 11:10:02.471047838 +0800 CST deployed mysql-1.6.9 5.7.30
1.4?定制参数部署应?
????????前?我们直接使? helm install 命令安装的 chart 包,通过 --set 进?参数传递。但我们如果有很多参数需要调整,使? --set 参数可能会变得?较复杂和不易管理。这时,我们可以选择通过?个特定的 values.yaml 配置?件来传递参数。
准备 values.yaml 值参数?件:
# 使用 helm show values 查看可以用到哪些参数
[root@k8s-master1 ~]# helm show values stable/mysql
[root@k8s-master1 ~]# vim values-mysql.yaml
mysqlDatabase: helm
mysqlRootPassword: Qwe123456
persistence:
enabled: true # 没有存储卷情况下,改为false
storageClass: nfs
livenessProbe:
initialDelaySeconds: 150
readinessProbe:
initialDelaySeconds: 150
使? -f values.yaml 安装应?并覆盖参数:
[root@k8s-master1 ~]# helm install mysql-02 -f values-mysql.yaml stable/mysql
[root@k8s-master1 ~]# helm ls
NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION
mysql-02 default 1 2024-01-09 15:11:36.612666187 +0800 CST deployed mysql-1.6.9 5.7.30
mysql-1704769258 default 2 2024-01-09 11:10:02.471047838 +0800 CST deployed mysql-1.6.9 5.7.30
查看该 release 传递的参数:
[root@k8s-master1 ~]# helm get values mysql-02
查看部署的相关资源:
[root@k8s-master1 ~]# kubectl get all -l release=mysql-02
1.5?chart 应?升级?
Helm 可以使? helm upgrade 命令来进?操作。更新的情况通常包括两种:
-
当需要更新或修改已有的 release 的配置时;
-
当应?的 chart 包有新的版本需要更新时。
????????Helm 升级,会尽量将应?的影响降到最低。它只会对发?改动的部分进?更新,?不是完全替换整个应?,这就是我们所说的 "最?侵?性" 升级。?
1、升级前先查看当前版本?
查看当前使?的镜像版本:mysql:5.7.30
[root@k8s-master1 ~]# kubectl get deployments -o wide -l release=mysql-02
NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR
mysql-02 1/1 1 1 10m mysql-02 mysql:5.7.30 app=mysql-02,release=mysql-02
2、修改 value.yaml 值?件(更新镜像的 tag),然后进?升级?
[root@k8s-master1 ~]# cat values-mysql.yaml
imageTag: "5.7.31"
mysqlDatabase: helm
mysqlRootPassword: Qwe123456
persistence:
enabled: true # 没有存储卷情况下,改为false
storageClass: nfs
livenessProbe:
initialDelaySeconds: 150
readinessProbe:
initialDelaySeconds: 150
3、执?升级操作
[root@k8s-master1 ~]# helm upgrade mysql-02 -f values-mysql.yaml stable/mysql
4、确认镜像版本是否升级成功
[root@k8s-master1 ~]# kubectl get deployments -o wide -l release=mysql-02
NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR
mysql-02 1/1 1 1 19m mysql-02 mysql:5.7.31 app=mysql-02,release=mysql-02
5、查看数据库版本进?验证
[root@k8s-master1 ~]# kubectl get pods -o wide -l release=mysql-02
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
mysql-02-64675c8b68-lhjp9 1/1 Running 0 6m33s 10.244.36.67 k8s-node1 <none> <none>
[root@k8s-master1 ~]# mysql -h 10.244.36.67 -uroot -pQwe123456 -e "select version();"
1.6?chart 应?回滚?
1、查看此前 mysql 的 charts 部署记录?
[root@k8s-master1 ~]# helm history mysql-02
REVISION UPDATED STATUS CHART APP VERSION DESCRIPTION
1 Tue Jan 9 15:11:36 2024 superseded mysql-1.6.9 5.7.30 Install complete
2 Tue Jan 9 15:27:14 2024 deployed mysql-1.6.9 5.7.30 Upgrade complete
2、将 mysql 的 chart 回退到 REVISON 版本 1?
[root@k8s-master1 ~]# helm rollback mysql-02 1
3、验证回滚结果
[root@k8s-master1 ~]# helm history mysql-02
REVISION UPDATED STATUS CHART APP VERSION DESCRIPTION
1 Tue Jan 9 15:11:36 2024 superseded mysql-1.6.9 5.7.30 Install complete
2 Tue Jan 9 15:27:14 2024 superseded mysql-1.6.9 5.7.30 Upgrade complete
3 Tue Jan 9 15:39:00 2024 deployed mysql-1.6.9 5.7.30 Rollback to 1
?4、查看应?的镜像是否回退
[root@k8s-master1 ~]# kubectl get deployments -o wide -l release=mysql-02
NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR
mysql-02 1/1 1 1 35m mysql-02 mysql:5.7.30 app=mysql-02,release=mysql-02
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!