五个冷门但非常实用的 Kubectl 使用技巧,99% 的人都不知道

2025-05-29 0 90

五个冷门但非常实用的 Kubectl 使用技巧,99% 的人都不知道

kubectl 是 K8s 官方附带的命令行工具,可以方便的操作 K8s 集群。这篇文章主要介绍一些 kubectl 的别样用法,希望读者有一定基础的 K8s 使用经验。

有一篇文章也介绍了一些技巧,写博客的时候正好搜到了,正好也分享出来吧。

Ready-to-use commands and tips for kubectl

打印当前使用的API

  1. #kubectl的主要作用就是与ApiServer进行交互,而交互的过程,我们可以通过下面的方式来打印,
  2. #这个命令尤其适合调试自己的api接口时使用.
  3. $kubectlgetns-v=9

五个冷门但非常实用的 Kubectl 使用技巧,99% 的人都不知道

按状态筛选容器以及删除

这是我在这里学到的命令:Force Delete Evicted / Terminated Pods in Kubernetes

  1. kubectlgetpods–all-namespaces–field-selectorstatus.phase=Pending-ojson|\\
  2. jq'.items[]|"kubectldeletepods\\(.metadata.name)-n\\(.metadata.namespace)"'|\\
  3. xargs-n1bash-c
  4. #这个命令要拆开来看
  5. #首先,获取所有ns中状态为Pending的pods,并以json形式输出
  6. #这个语句其实由很多变体,比如,我想查找Failed的状态,或是某个deployment
  7. kubectlgetpods–all-namespaces–field-selectorstatus.phase=Pending-ojson
  8. #针对json变量进行处理,生成可用的脚本
  9. #这里是我想介绍的重点,利用jq以及kubectl的输出,构建出可用的命令
  10. jq'.items[]|"kubectldeletepods\\(.metadata.name)-n\\(.metadata.namespace)"'
  11. #执行每一条命令
  12. #注意,这种命令一定要好好调试,删掉预期之外的pod就不好了.
  13. xargs-n1bash-c
  14. #例如,下面的语句可以找到所有的Pods并打印可以执行的语句
  15. kubectlgetpods–all-namespaces–field-selectorstatus.phase=Running-ojson|\\
  16. jq'.items[]|"kubectlgetpods\\(.metadata.name)-owide-n\\(.metadata.namespace)"'
  17. "kubectlgetpodsmetrics-server-6d684c7b5-gtd6q-owide-nkube-system"
  18. "kubectlgetpodslocal-path-provisioner-58fb86bdfd-98frc-owide-nkube-system"
  19. "kubectlgetpodsnginx-deployment-574b87c764-xppmx-owide-ndefault"
  20. #当然,如果只是删除单个NS下面的一些pods,我会选择下面的方法,但是它操作多个NS就很不方便了.
  21. kubectl-ndefaultgetpods|grepCompleted|awk'{print$1}'|xargskubectl-ndefaultdeletepods

统计具体某台机器上运行的所有pod

kubectl可以使用两种选择器, 一种是label, 一种是field, 可以看官网的介绍:

Labels and Selectors

Field Selectors

  1. #它是一种选择器,可以与上面的awk或者xargs配合使用.
  2. #我个人平时都不喜欢用这个,直接get全部pods,然后grep查找感觉更快
  3. kubectlgetpods–all-namespaces-owide–field-selectorspec.nodeName=pve-node1

统计 Pod 在不同机器的具体数量分布

不知道有读者看过我的这篇文章: 基于kubernetes的PaaS平台中细力度控制pods方案的实现。均衡分布的工作前提是得知pod在各个机器的分布情况。最好的办法就是我们得到pod信息之后进行简单的统计,这个工作可以使用awk实现。

  1. kubectl-ndefaultgetpods-owide-lapp="nginx"|awk'{print$7}'|\\
  2. awk'{count[$0]++}
  3. END{
  4. printf("%-35s:%s\\n","Word","Count");
  5. for(indincount){
  6. printf("%-35s:%d\\n",ind,count[ind]);
  7. }
  8. }'
  9. #执行结果如下
  10. Word:Count
  11. NODE:1
  12. pve-node1:1
  13. pve-node2:1
  14. #awk的语法我没深入了解,有兴趣的读者可以研究看看,这里我就不求甚解了.

kubectl proxy的使用

你可以理解为这个命令为 K8s 的 ApiServer 做了一层代理,使用该代理,你可以直接调用 API 而不需要经过鉴权。启动之后,甚至可以实现 kubectl 套娃,下面是一个例子:

  1. #当你没有设置kubeconfig而直接调用kubectl
  2. kubectlgetns-v=9
  3. #可以打印出下面类似的错误
  4. 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'
  5. skippedcachingdiscoveryinfoduetoGet"http://localhost:8080/api?timeout=32s":dialtcp127.0.0.1:8080:connect:connectionrefused
  6. #也就是说当你不指定kubeconfig文件时,kubectl会默认访问本机的8080端口
  7. #那么我们先启动一个kubectlproxy,然后指定监听8080,再使用kubectl直接访问,是不是就可行了呢,
  8. #事实证明,安全与预想一致.
  9. KUBECONFIG=~/.kube/config-symv3kubectlproxy-p8080
  10. kubectlgetns
  11. NAMESTATUSAGE
  12. defaultActive127d

默认启动的 proxy 是屏蔽了某些 api 的,并且有一些限制,例如无法使用 exec 进入 pod 之中可以使用 kubectl proxy —help 来看,例如:

  1. #仅允许本机访问
  2. –accept-hosts='^localhost$,^127\\.0\\.0\\.1$,^\\[::1\\]$':Regularexpressionforhoststhattheproxyshouldaccept.
  3. #不允许访问下面的api,也就是说默认没法exec进入容器
  4. –reject-paths='^/api/.*/pods/.*/exec,^/api/.*/pods/.*/attach':Regularexpressionforpathsthattheproxyshouldreject.Pathsspecifiedherewillberejectedevenacceptedby–accept-paths.
  5. #想跳过exec的限制也很简单,把reject-paths去掉就可以了
  6. kubectlproxy-p8080–keepalive3600s–reject-paths=''-v=9

有人说这个kubectl proxy可能没什么作用,那可能仅仅是你还没有实际的应用场景。例如当我想要调试K8s dashboard代码的时候。如果直接使用kubeconfig文件,我没法看到具体的请求过程,如果你加上一层proxy转发,并且设置-v=9的时候,你就自动获得了一个日志记录工具,在调试时相当有用。

总结

kubectl 是一个强大的命令行工具,上面我只是介绍了我工作中对其用法的一点探索,也并不鼓励大家非要记住这些命令,只是希望当读者需要的时候,能够想起来kubectl可以有类似的功能,就不需要针对几个临时需求去研读client-api了。

原文链接:https://mp.weixin.qq.com/s?__biz=MzA4Nzg5Nzc5OA==&mid=2651703981&idx=1&sn=2059afa7b8d2164e85c19752ef6808c6&chksm=8bcb0904bcbc8012ae08bb1058b60baf9f0e7c73acaf5b9fbc9fd5fb213e52bd4a2578073fc8&mpshare=1&

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 五个冷门但非常实用的 Kubectl 使用技巧,99% 的人都不知道 https://www.kuaiidc.com/91886.html

相关文章

发表评论
暂无评论