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

    文章

    2506

    浏览量

    67135
  • 工具
    +关注

    关注

    4

    文章

    319

    浏览量

    28948

原文标题:kubectl的多样用法

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

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    BERGQUIST热界面材料选型指南:满足多样化电子散热需求

    BERGQUIST热界面材料选型指南:满足多样化电子散热需求 在电子设备的设计中,热管理是一个至关重要的环节。有效的热管理能够确保电子设备在各种环境下稳定运行,延长其使用寿命。BERGQUIST作为
    的头像 发表于 05-16 14:30 513次阅读

    连接器的多样化应用有哪些?

    可以传输电力、信号和数据等信息,广泛应用于计算机、通信、汽车、航空航天和医疗设备等领域中。连接器的多样化应用有哪些?
    的头像 发表于 04-16 16:47 245次阅读
    连接器的<b class='flag-5'>多样</b>化应用有哪些?

    Kubernetes Pod启动失败的各种场景及其排障方法

    在 Kubernetes 日常运维中,Pod 起不来是最常见的故障形态之一。很多运维工程师看到 Pod 状态不是 Running 时,第一反应是盯着 kubectl get pod 的 STATUS
    的头像 发表于 04-13 13:53 164次阅读

    变频器的特殊用法

    变频器作为电力电子技术的重要应用设备,其核心功能是通过改变电源频率实现对电机转速的精确控制。然而在实际工业场景和创意应用中,工程师们早已突破传统认知,开发出一系列令人惊叹的特殊用法。这些创新实践不仅拓展了变频器的应用边界,更展现了电力电子技术的无限可能。
    的头像 发表于 03-03 17:08 666次阅读

    Kubernetes kubectl命令行工具详解

    kubectl是Kubernetes官方提供的命令行工具,作为与Kubernetes集群交互的主要接口,它通过调用Kubernetes API Server实现对集群资源的全面管理。在生产环境中,运维工程师需要熟练掌握kubectl命令来完成日常的集群运维、应用部署、故障
    的头像 发表于 02-02 16:40 687次阅读

    松下无线连接模块:多样选择,满足多元设计需求

    松下无线连接模块:多样选择,满足多元设计需求 在当今的电子设备设计中,无线连接功能至关重要。松下提供了丰富的无线连接模块产品线,涵盖蓝牙和 Wi-Fi 等多种技术,为电子工程师们带来了多样化的选择
    的头像 发表于 12-22 10:10 697次阅读

    奇异摩尔受邀出席2025多样性算力产业发展大会

    为探究多样性算力发展新模式、推动国内算力产业优化升级,中国通信标准化协会多样性算力产业及标准推进委员会(CCSA TC622)将于2025年11月18日在北京香格里拉饭店举办“多样性算力产业发展大会2025”,届时多位顶尖专家将
    的头像 发表于 11-19 17:45 1657次阅读
    奇异摩尔受邀出席2025<b class='flag-5'>多样</b>性算力产业发展大会

    C语言的printf基本用法介绍

    中使用频率最高的一个函数一点也不为过,每个C语言程序员都应该掌握 printf 的用法,这是最基本的技能。 不过 printf 的用法比较灵活,也比较复杂,初学者知识储备不足,不能一下子掌握,目前
    发表于 11-12 07:04

    电阻应变片的多样选择与应用

    电阻应变片作为一种重要的传感器技术,被广泛应用于压力、变形、应变测量等领域。其工作原理基于电阻随材料形变而变化的特性,能够将物理量转化为可测量的电信号。电阻应变片的种类繁多,各具特色,适用于不同的应用场景。本文将详细介绍电阻应变片的多样选择以及其在各个领域中的应用。
    的头像 发表于 08-30 15:44 1829次阅读

    芯片类型科普探索,解锁数字世界的多样力量

    本文转自:绿算技术数字科技蓬勃发展,芯片作为现代电子设备的核心驱动力,正以其多样化的类型和独特的功能,塑造着我们生活中的每一个角落。从智能手机的高效运作,到超级计算机的超强算力,芯片无处不在,默默
    的头像 发表于 08-19 12:37 1641次阅读
    芯片类型科普探索,解锁数字世界的<b class='flag-5'>多样</b>力量

    高效管理Kubernetes集群的实用技巧

    作为一名经验丰富的运维工程师,我深知在日常的Kubernetes集群管理中,熟练掌握kubectl命令是提升工作效率的关键。今天,我将分享15个经过实战检验的kubectl实用技巧,帮助你像艺术家一样优雅地管理K8s集群。
    的头像 发表于 08-13 15:57 1185次阅读

    【原创】labview 通过“引用调用“ 的快捷用法,不需编程获取VI引用

    labview的“通过引用调用”函数在调用严格类型VI时,通常需要获取VI的引用。该函数的输入端也确实有引用接口,如图: 但是该函数还有一个快捷用法,右键单击 引用调用 函数,弹出菜单中有“调用设置
    发表于 07-30 17:53

    k8s权限管理指南说明

    我们在目前的k8s集群环境里面,只能在master节点上执行kubectl的一些命令,在其他节点上执行就会报错。
    的头像 发表于 06-26 14:06 1029次阅读

    什么是 K8S,如何使用 K8S

    kubectl get pods -n <namespace>:列出 Pod。 kubectl get svc:查看 Service。 kubectl describe pod
    发表于 06-25 06:45

    海康威视科技助力守护生物多样性之美

    近日,由中国林业产业联合会指定的团体标准T/LYCY 3075-2024《生物多样性监测信息化技术规范》正式实施。作为该标准的牵头单位,海康威视凭借在生态监测领域的技术积累与实践经验,深度参与标准编写工作,为生物多样性监测信息化技术体系的构建贡献了重要力量。
    的头像 发表于 06-19 10:14 1224次阅读