一、 為什么要有helm?
K8S 上的應用對象,都是由特定的資源描述組成,包括 deployment、service 等。都保存 各自文件中或者集中寫到一個配置文件。然后 kubectl apply –f 部署。如果應用只由一 個或幾個這樣的服務組成,上面部署方式足夠了。而對於一個復雜的應用,會有很多類似 上面的資源描述文件,例如微服務架構應用,組成應用的服務可能多達十個,幾十個。如 果有更新或回滾應用的需求,可能要修改和維護所涉及的大量資源文件,而這種組織和管 理應用的方式就顯得力不從心了。且由於缺少對發布過的應用版本管理和控制,使 Kubernetes 上的應用維護和更新等面臨諸多的挑戰,主要面臨以下問題:(1)如何將這 些服務作為一個整體管理 (2)這些資源文件如何高效復用 (3)不支持應用級別的版本 管理
二、 helm 解決的問題
Helm 是一個 Kubernetes 的包管理工具,就像 Linux 下的包管理器,如 yum/apt 等,可以 很方便的將之前打包好的 yaml 文件部署到 kubernetes 上。
Helm 有 3 個重要概念:
(1)helm:一個命令行客戶端工具,主要用於 Kubernetes 應用 chart 的創建、打包、發 布和管理。
(2)Chart:應用描述,一系列用於描述 k8s 資源相關文件的集合。
(3)Release:基於 Chart 的部署實體,一個 chart 被 Helm 運行后將會生成對應的一個 release;將在 k8s 中創建出真實運行的資源對象。
三、安裝helm
helm的官方網址:https://helm.sh/
heml需要在k8s的主節點上安裝。
我們下載安裝包進行安裝,helm發布的版本地址如下:
https://github.com/helm/helm/releases
centos7環境,則選擇 Linux amd64 這個版本,下載地址如下:
https://get.helm.sh/helm-v3.7.1-linux-amd64.tar.gz

我們在K8s主節點上先創建個目錄。
mkdir myhelm
進入該目錄:
cd myhelm
下載:
curl -SLO https://get.helm.sh/helm-v3.7.1-linux-amd64.tar.gz
解壓:
tar -zxvf helm-v3.7.1-linux-amd64.tar.gz
將helm移至 /bin 目錄
mv linux-amd64/helm /usr/local/bin/helm
這樣就可以了。我們查看下版本號:
helm version

說明安裝成功了。
添加國內 阿里雲的 鏡像源:
helm repo remove stable
helm repo add stable http://mirror.azure.cn/kubernetes/charts/
helm repo update
也可以添加azure的源:(可選)
helm repo remove stable helm repo add stable http://mirror.azure.cn/kubernetes/charts/ helm repo add incubator http://mirror.azure.cn/kubernetes/charts-incubator/ helm repo update
搜索:
helm search repo redis
