成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Kubectl Foreach 在多個集群中執行 Kubectl 命令

云計算 云原生
今天偶然間發現了一個 kubectl 插件 kubectl foreach? ,可以在多個集群(contexts?)上執行 kubectl 命令。比如 kubectl foreach cluster-1 cluster-2 -- get po -n kube-system 。

上周在寫 K8s 多集群的流量調度 的 demo 部分時需要不停地在多個集群中安裝組件、部署應用,或者執行各種命令。當時是通過 Linux shell 腳本并通過工具 kubectx 進行集群的切換,像這樣:

圖片

或者這樣:

圖片

操作繁瑣,很是痛苦。

今天偶然間發現了一個 kubectl 插件 kubectl foreach? ,可以在多個集群(contexts?)上執行 kubectl 命令。比如 kubectl foreach cluster-1 cluster-2 -- get po -n kube-system 。

插件安裝和使用很簡單,通過 krew 進行安裝:

kubectl krew install foreach

使用也很簡單:

kubectl foreach -h
Usage:
kubectl foreach [OPTIONS] [PATTERN]... -- [KUBECTL_ARGS...]

Patterns can be used to match context names from kubeconfig:
(empty): matches all contexts
NAME: matches context with exact name
/PATTERN/: matches context with regular expression
^NAME: remove context with exact name from the matched results
^/PATTERN/: remove contexts matching the regular expression from the results

Options:
-c=NUM Limit parallel executions (default: 0, unlimited)
-I=VAL Replace VAL occurring in KUBECTL_ARGS with context name
-q Disable and accept confirmation prompts ($KUBECTL_FOREACH_DISABLE_PROMPTS)
-h/--help Print help

Examples:
# get nodes on contexts named a b c
kubectl foreach a b c -- get nodes

# get nodes on all contexts named c0..9 except c1 (note the escaping)
kubectl foreach '/^c[0-9]/' ^c1 -- get nodes

# get nodes on all contexts that has "prod" but not "foo"
kubectl foreach /prod/ ^/foo/ -- get nodes

# use 'kubectl tail' plugin to follow logs of pods in contexts named *test*
kubectl foreach -I _ /test/ -- tail --cnotallow=_ -l app=foo

接下來測試下,使用 k3d 創建 3 個集群 (k3d 貌似不支持同時創建多個集群,還是需要 for 腳本來操作):

for CLUSTER_NAME in cluster-1 cluster-2 cluster-3
do
k3d cluster create ${CLUSTER_NAME} \
--image docker.io/rancher/k3s:v1.23.8-k3s2 \
--servers-memory 4g \
--k3s-arg "--disable=traefik@server:0" \
--no-lb \
--timeout 120s \
--wait
done

集群安裝完成:

k3d cluster list
NAME SERVERS AGENTS LOADBALANCER
cluster-1 1/1 0/0 false
cluster-2 1/1 0/0 false
cluster-3 1/1 0/0 false

注意,k3d 安裝的集群的 context 都帶有前綴 k3d-? ,在使用 kubectl foreach 的時候要注意:

kubectx
k3d-cluster-1
k3d-cluster-2
k3d-cluster-3

比如查看各個集群中的 kube-sysmte 下的 pod:

kubectl foreach -q k3d-cluster-1 k3d-cluster-2 k3d-cluster-3 -- get po -n kube-system

圖片

或者試試創建 deployment,這次我們不列出完整的 context name,而是使用正則 /cluster/:

kubectl foreach -q /cluster/ -- create deploy pipy --image flomesh/pipy -n default
Will run command in context(s):
- k3d-cluster-1
- k3d-cluster-2
- k3d-cluster-3
k3d-cluster-1 | deployment.apps/pipy created
k3d-cluster-3 | deployment.apps/pipy created
k3d-cluster-2 | deployment.apps/pipy created

然后查看下 pod:

kubectl foreach -q /cluster/ -- get pod -n default
Will run command in context(s):
- k3d-cluster-1
- k3d-cluster-2
- k3d-cluster-3
k3d-cluster-1 | NAME READY STATUS RESTARTS AGE
k3d-cluster-1 | pipy-df659b55f-bnr27 1/1 Running 0 25s
k3d-cluster-3 | NAME READY STATUS RESTARTS AGE
k3d-cluster-3 | pipy-df659b55f-p9j49 1/1 Running 0 25s
k3d-cluster-2 | NAME READY STATUS RESTARTS AGE
k3d-cluster-2 | pipy-df659b55f-9bjgf 1/1 Running 0 25s

查看日志:

kubectl foreach -q /cluster/ -- logs -l app=pipy -n default --tail 3
Will run command in context(s):
- k3d-cluster-1
- k3d-cluster-2
- k3d-cluster-3
k3d-cluster-2 | 2022-11-30 10:40:56.520 [INF] [listener] Listening on TCP port 8080 at 0.0.0.0
k3d-cluster-2 | 2022-11-30 10:40:56.520 [INF] [listener] Listening on TCP port 8081 at 0.0.0.0
k3d-cluster-2 | 2022-11-30 10:40:56.520 [INF] [listener] Listening on TCP port 8082 at 0.0.0.0
k3d-cluster-1 | 2022-11-30 10:40:56.551 [INF] [listener] Listening on TCP port 8080 at 0.0.0.0
k3d-cluster-1 | 2022-11-30 10:40:56.551 [INF] [listener] Listening on TCP port 8081 at 0.0.0.0
k3d-cluster-1 | 2022-11-30 10:40:56.551 [INF] [listener] Listening on TCP port 8082 at 0.0.0.0
k3d-cluster-3 | 2022-11-30 10:40:55.813 [INF] [listener] Listening on TCP port 8080 at 0.0.0.0
k3d-cluster-3 | 2022-11-30 10:40:55.813 [INF] [listener] Listening on TCP port 8081 at 0.0.0.0
k3d-cluster-3 | 2022-11-30 10:40:55.813 [INF] [listener] Listening on TCP port 8082 at 0.0.0.0

注意,多集群的操作要謹慎,尤其是使用正則來匹配 context name;還有 ?-q 參數會跳過要操作的集群提醒,直接執行命令。?

責任編輯:武曉燕 來源: 云原生指北
相關推薦

2023-06-09 07:45:29

Kuberneteskubectl

2022-07-12 08:00:31

命令Kubernetes應用程序

2023-11-02 10:24:30

KubectlKubernetes

2020-09-10 08:10:21

Kubectl exeSSH

2022-05-21 07:56:32

Kubectl容器

2022-07-27 11:10:27

Kubectl命令運維

2020-02-25 21:32:59

TmuxkubectlKubernetes

2024-03-27 14:54:21

KubernetesK8S集群

2024-05-08 10:03:50

2022-12-09 08:10:12

kubectl容器源碼

2021-09-13 07:46:06

Kubectl Kubernetes 工具

2020-12-21 08:10:01

Kubernetes實用技巧kubectl

2022-06-02 10:02:47

Kubectl更新應用Linux

2018-01-18 10:57:48

Linux服務器命令

2021-11-12 14:50:32

Kubectl命令Linux

2021-02-22 08:29:03

KubernetesKubectl Fla應用

2021-09-24 14:20:25

開發技能工具

2024-12-31 08:12:30

容器Pod進程

2020-10-30 08:34:58

Kubernetes運維技巧

2021-08-13 11:21:16

KubernetesKubectlLinux
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩欧美成人精品 | 日韩视频免费在线 | 91视频亚洲 | 日韩 欧美 二区 | 亚洲精品国产综合区久久久久久久 | 中文字幕国产 | 国产精品一区二区免费 | 国产精品成人一区二区 | 久久99这里只有精品 | 欧美精品网站 | 欧美精品一区二区三区四区 在线 | 久久亚洲一区二区 | 中文字幕视频免费 | 午夜精品福利视频 | 国产欧美精品一区二区三区 | 一级片av | 精品欧美乱码久久久久久1区2区 | 成人精品一区亚洲午夜久久久 | 久热m3u8| 国产一二三区精品视频 | 伊人春色在线 | 高清欧美性猛交xxxx黑人猛交 | 日韩在线观看视频一区 | 亚洲女优在线播放 | 国产亚洲精品精品国产亚洲综合 | 亚洲免费在线观看av | 国产精品永久免费视频 | 亚洲 欧美 日韩在线 | 91免费在线视频 | 国产精品亚洲成在人线 | 日韩一级黄色毛片 | 国产日韩精品在线 | 黑人成人网 | 国产精品 欧美精品 | 91精品国产一区二区三区 | 精品久久久久久久久久久下田 | 美女国产一区 | 国产在线麻豆精品入口 | 欧美在线一区二区视频 | 免费在线一区二区三区 | 国产日韩91|