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

    浏览量

    62350
  • 工具
    +关注

    关注

    4

    文章

    314

    浏览量

    27893

原文标题:kubectl的多样用法

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    DAC7562的CLR引脚怎么用法?可以悬空吗?

    DAC7562的CLR引脚怎么用法?可以悬空吗?能不能详细解释一下?谢谢
    发表于 12-17 08:16

    详解kubectl常用命令

    详解kubectl常用命令
    的头像 发表于 11-05 15:39 338次阅读
    详解<b class='flag-5'>kubectl</b>常用命令

    Linux lsof命令的基本用法

    在 linux 系统中,一切皆文件。通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件。所以 lsof 命令不仅可以查看进程打开的文件、目录,还可以查看进程监听的端口等 socket 相关的信息。本文将介绍 lsof 命令的基本用法,本文中 demo 的演示环境为 ubuntu 18.04。
    的头像 发表于 10-23 11:52 414次阅读
    Linux lsof命令的基本<b class='flag-5'>用法</b>

    共模电感的用法

    呈现出大电感,具有抑制作用,而对于差模信号则呈现出很小的漏电感,几乎不起作用。以下是对共模电感用法的详细探讨。
    的头像 发表于 10-17 15:12 1004次阅读

    Sn74hc245具体的用法是什么?

    Sn74hc245是缓冲器,但是具体的用法不会
    发表于 09-10 07:32

    请问TLC352比较器的用法是否正确?

    以下比较器TLC352的用法是否正确?谢谢 TLC352含两个比较器,第二路不用,我是否可以把它的输入管脚IN2+, IN2-悬空? 它的输出是否是Open Drain? 也就是出高电平时,必须
    发表于 08-14 08:10

    SolidWorks教育版教学资源的多样

    在数字化教育日益普及的今天,一款能够提供多样化教学资源的软件工具对于工程教育的重要性不言而喻。SolidWorks教育版以其独特的功能和广泛的应用,为学生和教师提供了一系列丰富多样的教学资源,使工程学习更加生动有趣,实践更加有效便捷。
    的头像 发表于 06-26 17:35 472次阅读
    SolidWorks教育版教学资源的<b class='flag-5'>多样</b>性

    三菱PLC传送指令的用法

    三菱PLC(可编程逻辑控制器)在工业自动化领域中扮演着至关重要的角色。其中,传送指令(MOV)作为PLC编程中的基础指令之一,其正确使用对于实现数据的准确、高效传输至关重要。本文将详细讲解三菱PLC传送指令(MOV)的用法,包括指令的功能、格式、应用示例及注意事项等,以帮助读者更好地掌握其使用方法。
    的头像 发表于 06-18 09:41 4584次阅读

    鸿蒙Ability Kit(程序框架服务)【UIAbility组件基本用法

    UIAbility组件的基本用法包括:指定UIAbility的启动页面以及获取UIAbility的上下文[UIAbilityContext]。
    的头像 发表于 06-06 11:02 553次阅读
    鸿蒙Ability Kit(程序框架服务)【UIAbility组件基本<b class='flag-5'>用法</b>】

    InterfaceDesinger 使用案例-v1 -DDIO用法

      DDIO用法 对于输入输出IO很多时候会用到DDIO的用法。对于DDIO,就是时钟的双沿采集或者发送数据,所以必须要用到寄存器。它的设置也比较简单,在intefaceDesigner中添加
    的头像 发表于 05-20 16:30 951次阅读
    InterfaceDesinger 使用案例-v1 -DDIO<b class='flag-5'>用法</b>

    AWTK 开源串口屏开发(10) - 告警信息的高级用法

    告警信息是串口屏常用的功能,之前我们介绍了告警信息的基本用法,实现了告警信息的显示和管理。本文介绍一下实现查询告警信息和查看告警信息详情的方法。1.功能之前我们介绍了告警信息的基本用法,实现了告警
    的头像 发表于 02-24 08:23 360次阅读
    AWTK 开源串口屏开发(10) - 告警信息的高级<b class='flag-5'>用法</b>

    Kubectl核心命令总结:如何快速掌握K8s

    设置 kubectl 命令交互的 kubernetes 集群并修改配置信息。参阅 使用 kubeconfig 文件进行跨集群验证 获取关于配置文件的详细信息。
    的头像 发表于 02-23 14:43 498次阅读
    <b class='flag-5'>Kubectl</b>核心命令总结:如何快速掌握K8s

    verilog inout用法与仿真

    ,本文将详细讨论 inout 的用法和仿真。 首先,我们来了解一下 inout 的含义。 inout 是一种双向信号类型,即可以作为输入信号也可以作为输出信号。它类似于双向数据线,可以实现数据的双向传输。在硬件设计中, inout 可以用于与外部设备进行通信,如键盘、鼠标、显
    的头像 发表于 02-23 10:15 3271次阅读

    verilog function函数的用法

    Verilog 中被广泛用于对电路进行模块化设计,以简化和组织代码。 本文将详细介绍 Verilog 函数的用法,并探讨函数在硬件设计中的重要性和实际应用场景。 一. Verilog 函数概述 Verilog 函数通过提供一种结构化的方式来组织代码,并可以根据需要重复使用。它们可以在模块内部或外部定义,
    的头像 发表于 02-22 15:49 6013次阅读

    法拉电容放电保护原理是什么?如何正常使用法拉电容?

    法拉电容放电保护原理是什么?如何正常使用法拉电容? 法拉电容放电保护原理是指通过合理的设计和配置,保护法拉电容在放电过程中不受损坏的一种技术手段。法拉电容是一种具有高能量密度和长寿命的电容器
    的头像 发表于 02-02 11:34 2174次阅读