微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

k8s 之 helm包管理工具的简介安装使用

一:简介(Helm,Charts,Repoistory,Release)

Helm、Chart

Helm是Kubernetes的包管理器,类似于Python的pip centos的yum ubuntu的apt,主要用来管理 Charts,Charts是 Helm 的应用打包格式。chart 由一系列文件组成,这些文件描述了 Kubernetes 部署应用时所需要的资源,比如 Service、Deployment、PersistentVolumeClaim、Secret、ConfigMap 等。

单个的 chart 可以非常简单,只用于部署一个服务,比如 Memcached;chart 也可以很复杂,部署整个应用,比如包含 HTTP Servers、 Database、消息中间件、cache 等。换言之Helm Chart是用来封装Kubernetes原生应用程序的一系列YAML文件。可以在你部署应用的时候自定义应用程序的一些Metadata,以便于应用程序的分发。对于应用发布者而言,可以通过Helm打包应用、管理应用依赖关系、管理应用版本并发布应用到软件仓库。对于使用者而言,使用Helm后不用需要编写复杂的应用部署文件,可以以简单的方式在Kubernetes上查找、安装、升级、回滚、卸载应用程序。

Repository

Helm 的软件仓库,Repository 本质上是一个 Web 服务器,该服务器保存了一系列的 Chart 软件包以供用户下载,并且提供了一个该 Repository 的 Chart 包的清单文件以供查询。Helm 可以同时管理多个不同的 Repository。

Release

使用 helm install 命令在 Kubernetes 集群中部署的 Chart 称为 Release。可以理解为 Helm 使用 Chart 包部署的一个应用实例。

二:Helm安装

# 下载安装包并解压
$ wget https://get.helm.sh/helm-v3.3.4-linux-amd64.tar.gz
$ tart -zxvf helm-v3.3.4-linux-amd64.tar.gz
$ mv linux-amd64/helm /usr/local/bin/helm
# 查看helm版本
$ helm version
version.BuildInfo{Version:"v3.3.4", GitCommit:"a61ce5633af99708171414353ed49547cf05013d", GitTreeState:"clean", GoVersion:"go1.14.9"}
# 设置helm命令补齐:
$ echo "source <(helm completion bash)" >> ~/.bashrc
#先添加常用的chart源
$ helm repo add stable https://kubernetes-charts.storage.googleapis.com
$ helm repo add incubator https://kubernetes-charts-incubator.storage.googleapis.com  
$ helm repo add bitnami https://charts.bitnami.com/bitnami
$ helm repo add aliyuncs https://apphub.aliyuncs.com
#查看chart列表
[root@master Nginx]# helm repo list
NAME        URL                                                       
stable      https://kubernetes-charts.storage.googleapis.com          
incubator   https://kubernetes-charts-incubator.storage.googleapis.com
bitnami     https://charts.bitnami.com/bitnami                        
aliyuncs    https://apphub.aliyuncs.com 

  查看当前Nginx版本

[root@master Nginx]# helm search repo Nginx
NAME                                CHART VERSION   APP VERSION             DESCRIPTION                                       
aliyuncs/Nginx                      5.1.5           1.16.1                  Chart for the Nginx server                        
aliyuncs/nginx-ingress              1.30.3          0.28.0                  An Nginx Ingress controller that uses ConfigMap...
aliyuncs/nginx-ingress-controller   5.3.4           0.29.0                  Chart for the Nginx Ingress controller            
aliyuncs/Nginx-lego                 0.3.1                                   Chart for nginx-ingress-controller and kube-lego  
aliyuncs/Nginx-PHP                  1.0.0           Nginx-1.10.3_PHP-7.0    Chart for the Nginx PHP server                    
bitnami/Nginx                       6.2.1           1.19.2                  Chart for the Nginx server                        
bitnami/nginx-ingress-controller    5.5.1           0.35.0                  Chart for the Nginx Ingress controller            
stable/nginx-ingress                1.41.3          v0.34.1                 DEPRECATED! An Nginx Ingress controller that us...
stable/Nginx-ldapauth-proxy         0.1.4           1.13.5                  Nginx proxy with ldapauth                         
stable/Nginx-lego                   0.3.1                                   Chart for nginx-ingress-controller and kube-lego  
bitnami/kong                        1.3.2           2.1.3                   Kong is a scalable, open source API layer (aka ...
stable/gcloud-endpoints             0.1.2           1                       DEPRECATED Develop, deploy, protect and monitor...

 三、部署 

我们选择aliyuncs/Nginx 的chart包 先下载看看包有什么内容

helm pull aliyuncs/Nginx --untar #将Nginx包从创库拉到当前目录
#查看结构
[root@master charts]# tree Nginx/
Nginx/
├── Chart.yaml  #里面是Chart的配置
├── ci
│   └── values-with-ingress-metrics-and-serverblock.yaml
├── README.md
├── templates   #里面是yaml文件的集合
│   ├── deployment.yaml
│   ├── _helpers.tpl
│   ├── ingress.yaml
│   ├── NOTES.txt
│   ├── server-block-configmap.yaml
│   ├── servicemonitor.yaml
│   ├── svc.yaml
│   └── tls-secrets.yaml
├── values.schema.json
└── values.yaml   #全局变量

2 directories, 13 files

没有安装tree工具的可以

yum install tree

安装Nginx

[root@master charts]# helm install my-Nginx aliyuncs/Nginx --set service.type=NodePort --set persistence.enabled=false
NAME: my-Nginx
LAST DEPLOYED: Thu Sep 10 15:48:41 2020
NAMESPACE: default
STATUS: deployed
REVISION: 1
TEST SUITE: None
NOTES:
Get the Nginx URL:

  export NODE_PORT=$(kubectl get --namespace default -o jsonpath="{.spec.ports[0].nodePort}" services my-Nginx)
  export NODE_IP=$(kubectl get nodes --namespace default -o jsonpath="{.items[0].status.addresses[0].address}")
  echo "Nginx URL: http://$NODE_IP:$NODE_PORT/"

查看部署内容

[root@master charts]# kubectl get all
NAME                            READY   STATUS    RESTARTS   AGE
pod/my-Nginx-5b69568b97-c7rbz   1/1     Running   0          59s

NAME                 TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)                      AGE
service/kubernetes   ClusterIP   10.96.0.1      <none>        443/TCP                      24h
service/my-Nginx     NodePort    10.98.148.75   <none>        80:32218/TCP,443:30893/TCP   59s

NAME                       READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/my-Nginx   1/1     1            1           59s

NAME                                  DESIRED   CURRENT   READY   AGE
replicaset.apps/my-Nginx-5b69568b97   1         1         1       59s

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐