摘要:由兩部分組成,客戶端和服務(wù)端。其中運(yùn)行在集群上,管理,而客戶端就是一個(gè)命令行工具,可在本地運(yùn)行,一般運(yùn)行在持續(xù)集成持續(xù)交付的服務(wù)器上。命令行中的參數(shù)可以根據(jù)需要改成你自己期望的名字。
什么是Helm?這可不是暗黑破壞神里裝備的名稱:頭盔,而是Kubernetes的一個(gè)包管理工具,用來簡(jiǎn)化Kubernetes應(yīng)用的部署和管理。我們Helm和Kubernetes的關(guān)系,我們可以理解成yum和CentOS,apt-get和Ubuntu的關(guān)系。
Helm由兩部分組成,客戶端helm和服務(wù)端tiller。
其中tiller運(yùn)行在Kubernetes集群上,管理chart,而客戶端helm就是一個(gè)命令行工具,可在本地運(yùn)行,一般運(yùn)行在持續(xù)集成/持續(xù)交付的服務(wù)器上 。
下圖是helm的架構(gòu)圖。
我們現(xiàn)在就來試用下helm。
首先安裝helm客戶端。
下載helm執(zhí)行文件的壓縮包:
wget -O helm.tar.gz https://storage.googleapis.co... tar -xzf helm.tar.gz
解壓完畢后,將helm文件移到目錄/usr/local/bin/helm下面:
mv linux-amd64/helm /usr/local/bin/helm
給這個(gè)文件加上執(zhí)行權(quán)限:
chmod +x /usr/local/bin/helm
首先使用-namespace參數(shù)指定使用的namespace,我例子里的命名空間是part-0110:
helm init --tiller-namespace part-0110 --service-account access
helm init --tiller-namespace part-0110 --service-account access
Creating /home/vagrant/.helm
Creating /home/vagrant/.helm/repository
Creating /home/vagrant/.helm/repository/cache
Creating /home/vagrant/.helm/repository/local
Creating /home/vagrant/.helm/plugins
Creating /home/vagrant/.helm/starters
Creating /home/vagrant/.helm/cache/archive
Creating /home/vagrant/.helm/repository/repositories.yaml
Adding stable repo with URL: https://kubernetes-charts.sto...
Adding local repo with URL: http://127.0.0.1:8879/charts
$HELM_HOME has been configured at /home/vagrant/.helm.
Tiller (the Helm server-side component) has been installed into your Kubernetes Cluster.
Please note: by default, Tiller is deployed with an insecure "allow unauthenticated users" policy.
For more information on securing your installation see: https://docs.helm.sh/using_he...
Happy Helming!
從helm的init命令輸出,我們可以觀察到,該命令生成了大量和helm server交互所必須的repository。
現(xiàn)在可以使用helm version命令行參數(shù)查看helm客戶端和服務(wù)器端的版本號(hào):
helm version --tiller-connection-timeout=5 --tiller-namespace part-0110
vagrant@vagrant:~/.kube$ helm version --tiller-connection-timeout=5 --tiller-namespace part-0110
Client: &version.Version{SemVer:"v2.9.1", GitCommit:"20adb27c7c5868466912eebdf6664e7390ebe710", GitTreeState:"clean"}
Server: &version.Version{SemVer:"v2.9.1", GitCommit:"20adb27c7c5868466912eebdf6664e7390ebe710", GitTreeState:"clean"}
使用命令helm repo list查看helm倉(cāng)庫(kù)列表:
根據(jù)名稱搜索helm chart:
helm search chaoskube
使用下面的命令行安裝chart。命令行中的參數(shù)jerry可以根據(jù)需要改成你自己期望的名字。
helm install --name jerry stable/chaoskube --set namespaces=part-0110 --set rbac.serviceAccountName=access --tiller-namespace part-0110 --debug
下面是helm install命令的輸出,供您參考:
vagrant@vagrant:~/.kube$ helm install --name jerry stable/chaoskube --set namespaces=part-0110 --set rbac.serviceAccountName=access --tiller-namespace part-0110 --debug
[debug] Created tunnel using local port: "36408"
[debug] SERVER: "127.0.0.1:36408"
[debug] Original chart version: ""
[debug] Fetched stable/chaoskube to /home/vagrant/.helm/cache/archive/chaoskube-0.10.0.tgz
[debug] CHART PATH: /home/vagrant/.helm/cache/archive/chaoskube-0.10.0.tgz
NAME: jerry
REVISION: 1
RELEASED: Thu Nov 15 16:37:19 2018
CHART: chaoskube-0.10.0
USER-SUPPLIED VALUES:
namespaces: part-0110
rbac:
serviceAccountName: access
COMPUTED VALUES:
affinity: {}
annotations: null
debug: false
dryRun: true
excludedDaysOfYear: null
excludedTimesOfDay: null
excludedWeekdays: null
image: quay.io/linki/chaoskube
imageTag: v0.10.0
interval: 10m
labels: null
minimumAge: 0s
name: chaoskube
namespaces: part-0110
nodeSelector: {}
priorityClassName: ""
rbac:
create: false
serviceAccountName: access
replicas: 1
resources: {}
timezone: UTC
tolerations: []
HOOKS:
MANIFEST:
apiVersion: apps/v1beta1
kind: Deployment
metadata:
name: jerry-chaoskube
labels:
app: chaoskube
heritage: "Tiller"
release: "jerry"
chart: chaoskube-0.10.0
spec:
replicas: 1
selector:
matchLabels:
app: chaoskube
release: jerry
template:
metadata:
labels:
app: chaoskube
heritage: "Tiller"
release: "jerry"
chart: chaoskube-0.10.0
spec:
containers:
name: chaoskube
image: quay.io/linki/chaoskube:v0.10.0
args:
--interval=10m
--labels=
--annotations=
--namespaces=part-0110
--excluded-weekdays=
--excluded-times-of-day=
--excluded-days-of-year=
--timezone=UTC
--minimum-age=0s
resources:
{}
serviceAccountName: "access"
LAST DEPLOYED: Thu Nov 15 16:37:19 2018
NAMESPACE: part-0110
STATUS: DEPLOYED
RESOURCES:
==> v1beta1/Deployment
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
jerry-chaoskube 1 1 1 0 2s
==> v1/Pod(related)
NAME READY STATUS RESTARTS AGE
jerry-chaoskube-6689695476-kchtn 0/1 ContainerCreating 0 1s
NOTES:
chaoskube is running and will kill arbitrary pods every 10m.
You can follow the logs to see what chaoskube does:
POD=$(kubectl -n part-0110 get pods -l="release=jerry-chaoskube" --output=jsonpath="{.items[0].metadata.name}")
kubectl -n part-0110 logs -f $POD
You are running in dry-run mode. No pod is actually terminated.
使用helm list命令,現(xiàn)在就能查看到剛才安裝的名為jerry的chart了。
helm list --tiller-namespace part-0110
使用helm命令查看這個(gè)chart的明細(xì)(類似kubectl describe pod XXX )
helm status jerry --tiller-namespace part-0110
上圖也顯示了自動(dòng)生成的pod名稱為jerry-chaoskube-6689695476-kchtn,可以用kubectl log命令查看其運(yùn)行日志:
kubectl log jerry-chaoskube-6689695476-kchtn
要獲取更多Jerry的原創(chuàng)文章,請(qǐng)關(guān)注公眾號(hào)"汪子熙":
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/33090.html
摘要:由兩部分組成,客戶端和服務(wù)端。其中運(yùn)行在集群上,管理,而客戶端就是一個(gè)命令行工具,可在本地運(yùn)行,一般運(yùn)行在持續(xù)集成持續(xù)交付的服務(wù)器上。命令行中的參數(shù)可以根據(jù)需要改成你自己期望的名字。 什么是Helm?這可不是暗黑破壞神里裝備的名稱:頭盔,而是Kubernetes的一個(gè)包管理工具,用來簡(jiǎn)化Kubernetes應(yīng)用的部署和管理。我們Helm和Kubernetes的關(guān)系,我們可以理解成yum...
摘要:由兩部分組成,客戶端和服務(wù)端。其中運(yùn)行在集群上,管理,而客戶端就是一個(gè)命令行工具,可在本地運(yùn)行,一般運(yùn)行在持續(xù)集成持續(xù)交付的服務(wù)器上。命令行中的參數(shù)可以根據(jù)需要改成你自己期望的名字。 什么是Helm?這可不是暗黑破壞神里裝備的名稱:頭盔,而是Kubernetes的一個(gè)包管理工具,用來簡(jiǎn)化Kubernetes應(yīng)用的部署和管理。我們Helm和Kubernetes的關(guān)系,我們可以理解成yum...
摘要:參考中文指南使用管理應(yīng)用參考官方文檔,環(huán)境安裝時(shí)其指向安裝客戶端,版本參考。如下所示,在主機(jī)安裝當(dāng)前最新文檔版可選。 參考: Make a Kubernetes Operator in 15 minutes with Helm; Deploy Monocular on OpenShift; Helm中文指南; 使用Helm管理kubernetes應(yīng)用; https://he...
摘要:參考中文指南使用管理應(yīng)用參考官方文檔,環(huán)境安裝時(shí)其指向安裝客戶端,版本參考。如下所示,在主機(jī)安裝當(dāng)前最新文檔版可選。 參考: Make a Kubernetes Operator in 15 minutes with Helm; Deploy Monocular on OpenShift; Helm中文指南; 使用Helm管理kubernetes應(yīng)用; https://he...
摘要:廣告各版本離線安裝包祝賀發(fā)布在此獻(xiàn)上教程一份安裝安裝強(qiáng)勢(shì)插播廣告三步安裝,不多說安裝推薦生產(chǎn)環(huán)境用安裝,可以調(diào)參地址如我使用的版本這個(gè)不裝會(huì)報(bào)錯(cuò)先創(chuàng)建一個(gè)把管理員權(quán)限給安裝服務(wù)端如果已安裝更新加 廣告 | kubernetes各版本離線安裝包 祝賀istio1.0發(fā)布, 在此獻(xiàn)上教程一份 安裝 安裝k8s 強(qiáng)勢(shì)插播廣告 三步安裝,不多說 安裝helm, 推薦生產(chǎn)環(huán)境用helm安裝,...
閱讀 3258·2021-10-21 17:50
閱讀 3264·2021-10-08 10:05
閱讀 3400·2021-09-22 15:04
閱讀 589·2019-08-30 14:00
閱讀 1951·2019-08-29 17:01
閱讀 1517·2019-08-29 15:16
閱讀 3228·2019-08-26 13:25
閱讀 860·2019-08-26 11:44