本文只涉及Helm的Chart操做,不會對其餘知識進行過多描述。至於安裝這塊,麻煩自行百度吧,一大堆呢。html
在容器化的時代,咱們不少應用均可以部署在docker,很方便,而再進一步,咱們還有工具能夠對docker進行編排,Kubernetes就是一個很好的工具。再再進一步,Kubernetes出現了helm,能夠將多個服務更好的編排組合成一個應用。node
Helm的做用至關於node.js下的npm,對於應用發佈者而言,能夠經過Helm打包應用,管理應用依賴關係,管理應用版本併發布應用到軟件倉庫。git
Helm 是一個命令行下的客戶端工具。主要用於 Kubernetes 應用程序 Chart 的建立、打包、發佈以及建立和管理本地和遠程的 Chart 倉庫。github
chart是helm的應用打包格式。chart是描述相關的一組Kubernetes資源的文件集合。單個chart可能用於部署簡單的東西,好比memcached pod,或者一些複雜的東西,好比完整的具備HTTP服務,數據庫,緩存等的Web應用程序堆棧。docker
使用Helm建立Chartshell
windows下使用cmd或者powershell均可以,這裏我使用powershell,使用helm create命令建立一個wechat應用的chart。建立的目錄結構以下:數據庫
Chart.yaml:描述chart的概要信息,name和version是必須項。npm
values.yaml:chart支持在安裝時跟據參數進行定製化配置,values.yaml則提供了這些配置參數的默認值。windows
templates目錄:各種Kubernetes資源的配置模板都放在這裏。Helm會將valuees.yaml中的參數值注入模板中,生產標準的YAML配置文件。緩存
模板是Chart最重要部分,也是helm最強大的地方。模板增長了應用部署的靈活性,可以適用於不一樣的環境,雖然配置很複雜......
templates/NOTES.txt:chart的簡易使用文檔。
deployment.yaml,ingress.yaml,service.yaml就是咱們的模板了,固然咱們能夠把一個服務的配置模板用一個文件編寫,不一樣的資源配置咱們能夠用三個橫槓---來進行分割。
helm採用了GO語法來編寫chart,支持變量,對象,函數,流控制等功能。
templates/_helpers.tpl:定義子模版,在模板中{{ include "wechat.fullname" . }}就是引用子模板。
接下來咱們編寫一個本身的chart,沒有那麼複雜,只是chart的簡單操做。這裏我將咱們服務兩個微信服務(一個後臺,一個UI)打包成一個chart。
對於配置,這裏教你們一個偷懶的方式,能夠將現成服務的yaml配置直接拉下來,咱們是使用騰訊雲的容器服務,在已部署的服務中咱們能夠直接查看它的YAML配置,直接複製下來稍微改動便可。
這裏我將一個服務的資源配置模板寫在一個同一個yaml文件中,同時刪除非必需的內容。剩下以下內容。
然後我跟據須要將少數配置進行參數化,將須要參數化配置的內容寫在values.yaml中便可。這裏我只將iamge和ports進行參數化配置。
ui.yaml的配置同上,基本就算完成了。
TencentHub上傳Helm Chart有兩種方式,一種是使用helm打包後網頁直接上傳chart包,另外一種是使用helm命令行工具,使用命令helm push整個chart目錄。這裏咱們選擇後者。
在上傳以前咱們須要:
1.本地 Helm 客戶端添加 Tencent Hub 的 repo。
使用命令行輸入
helm repo add mycharts https://hub.tencentyun.com/charts/mycharts --username myname --password mypassword
2.安裝Tencent Hub 的 helm-push 插件。
使用命令行輸入
helm plugin install https://github.com/imroc/helm-push
完成後咱們就能夠上傳Helm Chart了。
使用命令
上傳文件夾
helm push ./myapp mycharts
上傳壓縮包
helm push myapp-1.0.1.tgz mychart
上傳成功後在Tencent Hub便可看到咱們上傳的chart的信息了
好了,到這就結束了,接下來還有一篇部署Chart應用並使用.net core讀取Kubernetes中的configMap
寫寫騰訊雲使用chart部署應用以及.net core使用k8s做爲配置中心,如何讀取configMap。以及中間遇到的一些坑吧......