吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

kubectl的多樣用法

馬哥Linux運維 ? 來源:馬哥Linux運維 ? 2023-02-13 10:53 ? 次閱讀

kubectl是K8s官方附帶的命令行工具, 可以方便的操作K8s集群. 這篇文章主要介紹一些kubectl的別樣用法, 希望讀者有基礎的K8s使用經驗.

打印當前使用的API

#kubectl的主要作用就是與ApiServer進行交互,而交互的過程,我們可以通過下面的方式來打印,
#這個命令尤其適合調試自己的api接口時使用.
kubectlgetns-v=9

e8c1410e-aaa3-11ed-bfe3-dac502259ad0.png

按狀態篩選容器以及刪除

kubectlgetpods--all-namespaces--field-selectorstatus.phase=Pending-ojson|
jq'.items[]|"kubectldeletepods(.metadata.name)-n(.metadata.namespace)"'|
xargs-n1bash-c


#這個命令要拆開來看
#首先,獲取所有ns中狀態為Pending的pods,并以json形式輸出
#這個語句其實由很多變體,比如,我想查找Failed的狀態,或是某個deployment
kubectlgetpods--all-namespaces--field-selectorstatus.phase=Pending-ojson

#針對json變量進行處理,生成可用的腳本
#這里是我想介紹的重點,利用jq以及kubectl的輸出,構建出可用的命令
jq'.items[]|"kubectldeletepods(.metadata.name)-n(.metadata.namespace)"'

#執行每一條命令
#注意,這種命令一定要好好調試,刪掉預期之外的pod就不好了.
xargs-n1bash-c


#例如,下面的語句可以找到所有的Pods并打印可以執行的語句
kubectlgetpods--all-namespaces--field-selectorstatus.phase=Running-ojson|
jq'.items[]|"kubectlgetpods(.metadata.name)-owide-n(.metadata.namespace)"'

"kubectlgetpodsmetrics-server-6d684c7b5-gtd6q-owide-nkube-system"
"kubectlgetpodslocal-path-provisioner-58fb86bdfd-98frc-owide-nkube-system"
"kubectlgetpodsnginx-deployment-574b87c764-xppmx-owide-ndefault"

#當然,如果只是刪除單個NS下面的一些pods,我會選擇下面的方法,但是它操作多個NS就很不方便了.
kubectl-ndefaultgetpods|grepCompleted|awk'{print$1}'|xargskubectl-ndefaultdeletepods

統計具體某臺機器上運行的所有pod

kubectl可以使用兩種選擇器, 一種是label, 一種是field, 可以看官網的介紹: Labels and Selectors Field Selectors

#它是一種選擇器,可以與上面的awk或者xargs配合使用.
#我個人平時都不喜歡用這個,直接get全部pods,然后grep查找感覺更快
kubectlgetpods--all-namespaces-owide--field-selectorspec.nodeName=pve-node1

統計Pod在不同機器的具體數量分布

不知道有讀者看過我的這篇文章: 基于kubernetes的PaaS平臺中細力度控制pods方案的實現. 均衡分布的工作前提是得知pod在各個機器的分布情況. 最好的辦法就是我們得到pod信息之后進行簡單的統計, 這個工作可以使用awk實現.

kubectl-ndefaultgetpods-owide-lapp="nginx"|awk'{print$7}'|
awk'{count[$0]++}
END{
printf("%-35s:%s
","Word","Count");
for(indincount){
printf("%-35s:%d
",ind,count[ind]);
}
}'

#執行結果如下
Word:Count
NODE:1
pve-node1:1
pve-node2:1


#awk的語法我沒深入了解,有興趣的讀者可以研究看看,這里我就不求甚解了.

kubectl proxy的使用

你可以理解為這個命令為K8s的ApiServer做了一層代理, 使用該代理, 你可以直接調用API而不需要經過鑒權. 啟動之后, 甚至可以實現kubectl套娃, 下面是一個例子:

#當你沒有設置kubeconfig而直接調用kubectl時
kubectlgetns-v=9
#可以打印出下面類似的錯誤
curl-k-v-XGET-H"Accept:application/json,*/*"-H"User-Agent:kubectl/v1.21.3(linux/amd64)kubernetes/ca643a4"'http://localhost:8080/api?timeout=32s'
skippedcachingdiscoveryinfoduetoGet"http://localhost:8080/api?timeout=32s":dialtcp127.0.0.1connect:connectionrefused
#也就是說當你不指定kubeconfig文件時,kubectl會默認訪問本機的8080端口
#那么我們先啟動一個kubectlproxy,然后指定監聽8080,再使用kubectl直接訪問,是不是就可行了呢,
#事實證明,安全與預想一致.
KUBECONFIG=~/.kube/config-symv3kubectlproxy-p8080
kubectlgetns
NAMESTATUSAGE
defaultActive127d

默認啟動的proxy是屏蔽了某些api的, 并且有一些限制, 例如無法使用exec進入pod之中 可以使用kubectl proxy --help來看, 例如

#僅允許本機訪問
--accept-hosts='^localhost$,^127.0.0.1$,^[::1]$':Regularexpressionforhoststhattheproxyshouldaccept.
#不允許訪問下面的api,也就是說默認沒法exec進入容器
--reject-paths='^/api/.*/pods/.*/exec,^/api/.*/pods/.*/attach':Regularexpressionforpathsthattheproxyshouldreject.Pathsspecifiedherewillberejectedevenacceptedby--accept-paths.

#想跳過exec的限制也很簡單,把reject-paths去掉就可以了
kubectlproxy-p8080--keepalive3600s--reject-paths=''-v=9

有人說這個kubectl proxy可能沒什么作用, 那可能僅僅是你還沒有實際的應用場景. 例如當我想要調試K8s dashboard代碼的時候. 如果直接使用kubeconfig文件, 我沒法看到具體的請求過程, 如果你加上一層proxy轉發, 并且設置-v=9的時候, 你就自動獲得了一個日志記錄工具, 在調試時相當有用.

總結

kubectl是一個強大的命令行工具, 上面我只是介紹了我工作中對其用法的一點探索, 也并不鼓勵大家非要記住這些命令, 只是希望當讀者需要的時候, 能夠想起來kubectl可以有類似的功能, 就不需要針對幾個臨時需求去研讀client-api了.

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • API
    API
    +關注

    關注

    2

    文章

    1510

    瀏覽量

    62396
  • 工具
    +關注

    關注

    4

    文章

    314

    瀏覽量

    27911

原文標題:kubectl的多樣用法

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    DAC7562的CLR引腳怎么用法?可以懸空嗎?

    DAC7562的CLR引腳怎么用法?可以懸空嗎?能不能詳細解釋一下?謝謝
    發表于 12-17 08:16

    詳解kubectl常用命令

    詳解kubectl常用命令
    的頭像 發表于 11-05 15:39 ?350次閱讀
    詳解<b class='flag-5'>kubectl</b>常用命令

    Linux lsof命令的基本用法

    在 linux 系統中,一切皆文件。通過文件不僅僅可以訪問常規數據,還可以訪問網絡連接和硬件。所以 lsof 命令不僅可以查看進程打開的文件、目錄,還可以查看進程監聽的端口等 socket 相關的信息。本文將介紹 lsof 命令的基本用法,本文中 demo 的演示環境為 ubuntu 18.04。
    的頭像 發表于 10-23 11:52 ?423次閱讀
    Linux lsof命令的基本<b class='flag-5'>用法</b>

    共模電感的用法

    呈現出大電感,具有抑制作用,而對于差模信號則呈現出很小的漏電感,幾乎不起作用。以下是對共模電感用法的詳細探討。
    的頭像 發表于 10-17 15:12 ?1047次閱讀

    Sn74hc245具體的用法是什么?

    Sn74hc245是緩沖器,但是具體的用法不會
    發表于 09-10 07:32

    請問TLC352比較器的用法是否正確?

    以下比較器TLC352的用法是否正確?謝謝 TLC352含兩個比較器,第二路不用,我是否可以把它的輸入管腳IN2+, IN2-懸空? 它的輸出是否是Open Drain? 也就是出高電平時,必須
    發表于 08-14 08:10

    SolidWorks教育版教學資源的多樣

    在數字化教育日益普及的今天,一款能夠提供多樣化教學資源的軟件工具對于工程教育的重要性不言而喻。SolidWorks教育版以其獨特的功能和廣泛的應用,為學生和教師提供了一系列豐富多樣的教學資源,使工程學習更加生動有趣,實踐更加有效便捷。
    的頭像 發表于 06-26 17:35 ?479次閱讀
    SolidWorks教育版教學資源的<b class='flag-5'>多樣</b>性

    三菱PLC傳送指令的用法

    三菱PLC(可編程邏輯控制器)在工業自動化領域中扮演著至關重要的角色。其中,傳送指令(MOV)作為PLC編程中的基礎指令之一,其正確使用對于實現數據的準確、高效傳輸至關重要。本文將詳細講解三菱PLC傳送指令(MOV)的用法,包括指令的功能、格式、應用示例及注意事項等,以幫助讀者更好地掌握其使用方法。
    的頭像 發表于 06-18 09:41 ?4625次閱讀

    PLC中SFTL指令的用法

    Left Logical)指令是PLC指令集中的一種重要指令,用于處理數據的左移操作。本文將詳細闡述PLC指令SFTL的用法,包括其定義、語法、功能、使用方法以及應用場景等方面,以期為工程師和技術人員提供參考。
    的頭像 發表于 06-15 17:48 ?3649次閱讀

    鴻蒙Ability Kit(程序框架服務)【UIAbility組件基本用法

    UIAbility組件的基本用法包括:指定UIAbility的啟動頁面以及獲取UIAbility的上下文[UIAbilityContext]。
    的頭像 發表于 06-06 11:02 ?556次閱讀
    鴻蒙Ability Kit(程序框架服務)【UIAbility組件基本<b class='flag-5'>用法</b>】

    InterfaceDesinger 使用案例-v1 -DDIO用法

    ? DDIO用法 對于輸入輸出IO很多時候會用到DDIO的用法。對于DDIO,就是時鐘的雙沿采集或者發送數據,所以必須要用到寄存器。它的設置也比較簡單,在intefaceDesigner中添加
    的頭像 發表于 05-20 16:30 ?958次閱讀
    InterfaceDesinger 使用案例-v1 -DDIO<b class='flag-5'>用法</b>

    AWTK 開源串口屏開發(10) - 告警信息的高級用法

    告警信息是串口屏常用的功能,之前我們介紹了告警信息的基本用法,實現了告警信息的顯示和管理。本文介紹一下實現查詢告警信息和查看告警信息詳情的方法。1.功能之前我們介紹了告警信息的基本用法,實現了告警
    的頭像 發表于 02-24 08:23 ?368次閱讀
    AWTK 開源串口屏開發(10) - 告警信息的高級<b class='flag-5'>用法</b>

    Kubectl核心命令總結:如何快速掌握K8s

    設置 kubectl 命令交互的 kubernetes 集群并修改配置信息。參閱 使用 kubeconfig 文件進行跨集群驗證 獲取關于配置文件的詳細信息。
    的頭像 發表于 02-23 14:43 ?501次閱讀
    <b class='flag-5'>Kubectl</b>核心命令總結:如何快速掌握K8s

    verilog inout用法與仿真

    ,本文將詳細討論 inout 的用法和仿真。 首先,我們來了解一下 inout 的含義。 inout 是一種雙向信號類型,即可以作為輸入信號也可以作為輸出信號。它類似于雙向數據線,可以實現數據的雙向傳輸。在硬件設計中, inout 可以用于與外部設備進行通信,如鍵盤、鼠標、顯
    的頭像 發表于 02-23 10:15 ?3295次閱讀

    verilog function函數的用法

    Verilog 中被廣泛用于對電路進行模塊化設計,以簡化和組織代碼。 本文將詳細介紹 Verilog 函數的用法,并探討函數在硬件設計中的重要性和實際應用場景。 一. Verilog 函數概述 Verilog 函數通過提供一種結構化的方式來組織代碼,并可以根據需要重復使用。它們可以在模塊內部或外部定義,
    的頭像 發表于 02-22 15:49 ?6043次閱讀
    尊龙百家乐官网娱乐平台| 新葡京娱乐城官方网址| 百家乐官网娱乐城信息| 百家乐赌场破解方法| 碌曲县| 百家乐最新庄闲投注法| 百家乐官网必学技巧| 天天百家乐的玩法技巧和规则| 百家乐官网游戏平台有哪些哪家的口碑最好 | 凯斯娱乐| 川宜百家乐破解版| 百家乐官网账号变动原因| 大发888心得| 百家乐真人游戏开户| 保单机百家乐官网破解方法 | 三门县| 百家乐棋牌游戏币| 百家乐官网平注法到656| 澳门皇冠娱乐城| 真钱百家乐游戏大全| 百家乐官网是赌博吗| 百家乐破解分| 皇冠网小说网址| 线上百家乐赢钱| 百家乐官网扑克桌布| 澳门顶级赌场金沙| 百家乐软件辅助| 玩百家乐官网优博娱乐城| 爱玩棋牌官方下载| 百家乐娱乐软件| 海王星百家乐官网的玩法技巧和规则 | 水果机上分器| 缅甸百家乐官网赌场| 优博百家乐官网现金网| 大赢家百家乐的玩法技巧和规则| 荷规则百家乐官网的玩法技巧和规则| 凯斯网娱乐城| 欢乐谷百家乐的玩法技巧和规则| 百家乐官网官网| 大发888的示例| 电子百家乐作假|