helm系列之-使用helm部署应用

使用helm部署应用

Helm 是一个 Kubernetes 的包管理工具,用于简化应用的部署和管理。下面是用helm在k8s上部署应用的一般流程。

  1. 添加helm仓库
# 添加仓库
root@master1:~# helm repo add aliyun  https://kubernetes.oss-cn-hangzhou.aliyuncs.com/charts
root@master1:~# helm repo add bitnami https://charts.bitnami.com/bitnami

# 更新
root@master1:~# helm repo update
Hang tight while we grab the latest from your chart repositories...
...Successfully got an update from the "aliyun" chart repository
...Successfully got an update from the "harbor" chart repository
...Successfully got an update from the "gitlab-jh" chart repository
...

# 仓库列表
root@master1:~# helm repo list
NAME            URL
ingress-nginx   https://kubernetes.github.io/ingress-nginx
openebs         https://openebs.github.io/openebs
harbor          https://helm.goharbor.io
jenkins         https://charts.jenkins.io
gitlab          https://charts.gitlab.io/
gitlab-jh       https://charts.gitlab.cn
bitnami         https://charts.bitnami.com/bitnami
aliyun          https://kubernetes.oss-cn-hangzhou.aliyuncs.com/charts

# 删除
helm repo remove xxx
  1. 搜索应用
root@master1:~# helm search repo nginx
NAME                                    CHART VERSION   APP VERSION     DESCRIPTION
aliyun/nginx-ingress                    0.9.5           0.10.2          An nginx Ingress controller that uses ConfigMap...
aliyun/nginx-lego                       0.3.1                           Chart for nginx-ingress-controller and kube-lego
bitnami/nginx                           18.1.4          1.27.0          NGINX Open Source is a web server that can be a...
bitnami/nginx-ingress-controller        11.3.12         1.11.0          NGINX Ingress Controller is an Ingress controll...
bitnami/nginx-intel                     2.1.15          0.4.9           DEPRECATED NGINX Open Source for Intel is a lig...
ingress-nginx/ingress-nginx             4.11.0          1.11.0          Ingress controller for Kubernetes using NGINX a...
aliyun/gcloud-endpoints                 0.1.0                           Develop, deploy, protect and monitor your APIs ...

默认情况下可以直接部署官方发布的chart,也可以下拉取到本地后进行修改。

  1. 修改chart
# 拉取chart
root@master1:~# helm pull bitnami/nginx --version 18.1.4

# 解压缩chart
root@master1:~# tar xf nginx-18.1.4.tgz
root@master1:~# cd nginx/
root@master1:~/nginx# ls
Chart.lock  charts  Chart.yaml  README.md  templates  values.schema.json  values.yaml
root@master1:~/nginx# vim values.yaml

global:
  imageRegistry: "harbor.test.com"  # 改为私有的helm仓库,此处为本地的harbor服务器
  ## E.g.
  ## imagePullSecrets:
  ##   - myRegistryKeySecretName
...
image:
  registry: docker.io
  repository: bitnami/nginx
  tag: 1.27.0-debian-12-r3    # 根据本地harbor仓库的nginx镜像,修改repository和tag。registry可以不用修改,使用global配置。
  digest: ""
  ## Specify a imagePullPolicy

...
service:
  ## @param service.type Service type
  ##
  type: LoadBalancer  # 默认为LoadBalancer,如果没有LB可以修改为NodePort或ClusterIP等。
  ## @param service.ports.http Service HTTP port
  ## @param service.ports.https Service HTTPS port
  ##
  ports:

备注

  1. Helm chart 通常包含一个 values.yaml 文件,用于配置应用的参数。
  2. 也可以使用 --values 参数指定一个自定义的 values.yaml 文件。
  3. 也可以通过 --set 参数在命令行中设置参数:

helm install my-nginx stable/nginx --set service.type=LoadBalancer

  1. 将nginx镜像下载后推送到本地harbor仓库
# 从docker hub下载nginx镜像
nerdctl pull bitnami/nginx:1.27.0-debian-12-r3

# 重新打tag推送到本地的harbor
nerdctl tag bitnami/nginx:1.27.0-debian-12-r3 harbor.test.com/bitnami/nginx:1.27.0-debian-12-r3
# 推送之前需要在harbor上创建bitnami的项目
nerdctl push harbor.test.com/bitnami/nginx:1.27.0-debian-12-r3
  1. 此时部署chart,镜像默认会从本地的harbor去拉取
root@master1:~/nginx/nginx# ls
Chart.lock  charts  Chart.yaml  README.md  templates  values.schema.json  values.yaml

root@master1:~/nginx/nginx# helm install webapp .
root@master1:~/nginx/nginx# helm status webapp
  1. 检查部署的nginx
root@master1:~/nginx/nginx# kubectl get pod
NAME                              READY   STATUS    RESTARTS       AGE
webapp-nginx-7958699dc-45stm      1/1     Running   0              10m
root@master1:~/nginx/nginx# kubectl get svc
NAME             TYPE           CLUSTER-IP    EXTERNAL-IP     PORT(S)                      AGE
kubernetes       ClusterIP      10.96.0.1     <none>          443/TCP                      21d
webapp-nginx     LoadBalancer   10.98.11.69   192.168.0.242   80:32079/TCP,443:32506/TCP   17m

本文使用的环境有LB,访问http://192.168.0.242即可看到nginx页面。

  1. 升级部署的应用

helm upgrade webapp . --values values.yaml

  1. 删除部署的应用

helm uninstall webapp

默认为default,删除指定命名空间需要指定-n <ns-name>

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Helm是一个开源的Kubernetes应用包管理工具,用于简化Kubernetes应用部署和管理。通过Helm,我们可以将应用打包为一个可重复使用的Chart,然后在Kubernetes集群中进行部署。 首先,我们需要安装Helm客户端工具。可以从Helm官方网站上下载适合自己操作系统的版本,并根据安装说明进行安装。 安装完成后,我们可以使用Helm命令行工具来创建一个新的Chart。一个Chart包含了应用的全部资源定义,包括Deployment、Service、Ingress等。我们可以使用helm create命令创建一个新的Chart,并根据需求修改Chart文件夹下的各个模板文件。 在Chart文件夹下,最重要的文件是values.yaml。该文件定义了Chart的默认值,我们可以在部署时通过传入自定义的values文件来覆盖这些默认值。这样,我们可以根据不同环境和需求来定制化应用部署配置。 在部署之前,我们可以使用helm lint命令来检查Chart是否符合Helm的规范。一旦通过了lint检查,我们就可以使用helm install命令来将应用部署Kubernetes集群中。 在部署完成后,我们可以使用helm list命令来查看已部署应用,以及相关的版本信息和状态。如果需要升级应用或回滚到之前的版本,我们可以使用helm upgrade和helm rollback命令。 除了部署应用,Helm还提供了一些其他功能,如搜索和安装Chart仓库中的应用、打包和分享自己的Chart等。通过Helm,我们可以更方便地管理和扩展Kubernetes应用,提高开发和部署的效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lldhsds

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值