helm是kubernetes的包管理工具,用於簡化部署和管理 Kubernetes 應用。用來管理charts——預先配置好的安裝包資源。
Helm和charts的主要做用:
應用程序封裝
版本管理
依賴檢查
便於應用程序分發
helm是一個C/S框架的軟件,helm至關於一個客戶端,tiller是一個服務端
Helm CLI 是 Helm 客戶端,能夠在本地執行
Tiller 是服務器端組件,在 Kubernetes 羣集上運行,並管理 Kubernetes 應用程序的生命週期
Repository 是 Chart 倉庫,Helm客戶端經過HTTP協議來訪問倉庫中Chart的索引文件和壓縮包
Helm工做原理
Chart Install 過程:
Helm從指定的目錄或者tgz文件中解析出Chart結構信息
Helm將指定的Chart結構和Values信息經過gRPC傳遞給Tiller
Tiller根據Chart和Values生成一個Release
Tiller將Release發送給Kubernetes用於生成Releaselinux
Chart Update過程:
Helm從指定的目錄或者tgz文件中解析出Chart結構信息
Helm將要更新的Release的名稱和Chart結構,Values信息傳遞給Tiller
Tiller生成Release並更新指定名稱的Release的History
Tiller將Release發送給Kubernetes用於更新Releasedocker
Chart Rollback過程:
Helm將要回滾的Release的名稱傳遞給Tiller
Tiller根據Release的名稱查找History
Tiller從History中獲取上一個Release
Tiller將上一個Release發送給Kubernetes用於替換當前Release服務器
curl -LO https://www.cnrancher.com/download/helm/helm-v2.14.3-linux-amd64.tar.gz tar -xvf helm-v2.14.3-linux-amd64.tar.gz sudo cp linux-amd64/helm /usr/local/bin/
查看版本信息框架
$ helm version Client: &version.Version{SemVer:"v2.14.3", GitCommit:"0e7f3b6637f7af8fcfddb3d2941fcc7cbebb0085", GitTreeState:"clean"} Error: could not find tiller
建立服務帳戶curl
kubectl -n kube-system create serviceaccount tiller kubectl create clusterrolebinding tiller --clusterrole cluster-admin --serviceaccount=kube-system:tiller
初始化tiller
注意:離線環境中須要顯式指明 --tiller-image,而且須要與helm client的版本一致,如上面的v2.14.3,下面經過環境變量方式自動選擇合適版本ide
docker pull zhaojiajie/kubernetes-helm/tiller:v2.14.3 helm init --service-account tiller --tiller-image rancher/tiller:v2.14.3 --skip-refresh $ kubectl get pods --namespace kube-system | grep tiller tiller-deploy-65cff4d7bc-g9gzm 1/1 Running 0 11d
$ helm version Client: &version.Version{SemVer:"v2.14.3", GitCommit:"0e7f3b6637f7af8fcfddb3d2941fcc7cbebb0085", GitTreeState:"clean"} Server: &version.Version{SemVer:"v2.14.3", GitCommit:"0e7f3b6637f7af8fcfddb3d2941fcc7cbebb0085", GitTreeState:"clean"}