如何通过shell脚本查看k8s日志(k8s,shell,开发技术)

时间:2024-05-08 00:52:42 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

查看日志:kubectl logs -f podName --tail 100

比如我们如果想查指定的pod,指定行数,指定的内容,
每次都需要输入kubectl logs -f xxx --tail yyy | grep zzz
为了方便,可自定义脚本,输入sh .sh xxx yyy zzz即可,并且xxx支持RE;

占位符的方式

#!/bin/bash#kubectlgetpods#notificationx="kubectllogs-f"y="--tail"g="|grep"name=`kubectlgetpods|grep^$1|awk'{print$1}'`x="eval$x$name$y$2$g$3"${x}#shlog.shpodName20content#最终:kubectllogs-fpodName--tail20|grepcontent

指定参数 getopts

#!/bin/bash#":":如果某个选项(option)后面出现了冒号(":"),则表示这个选项后面可以接参数x="kubectllogs-f"y="--tail"g="|grep"whilegetopts":n:f:c:"optdocase$optinn) name=`kubectlgetpods|grep^$OPTARG|awk'{print$1}'` x="$x$name";;f) x="$x$y$OPTARG";;c)x="$x$g$OPTARG";;?)echo"未知参数"exit1;;esacdonex="eval$x"${x}#shlog.sh-npodName-f20-ccontent#最终:kubectllogs-fpodName--tail20|grepcontent

问题

1.执行 shell 脚本\r问题

脚本是在window下编辑完成后上传到linux上执行的,win下的换行是回车符+换行符,也就是\r\n,而unix下是换行符\n。linux下不识别\r为回车符,所以导致每行的配置都多了个\r,因此是脚本编码的问题。

如何通过shell脚本查看k8s日志

2.命令中的grep

如何通过shell脚本查看k8s日志

可以发现最终拼接出来的字符串,是一条正确的命令,但是通过${CMD}执行该变量报错。

原因:
如果在shell中定义一个命令,带了管道,例如

CMD=“ls -l | grep xx”

直接执行$CMD,会出现如下报错

ls: cannot access |: No such file or directory

ls: cannot access grep: No such file or directory

管道符会被解释为普通字符

加上eval

CMD=“eval ls -l | grep xx”

如何通过shell脚本查看k8s日志

 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:如何通过shell脚本查看k8s日志的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:JavaScript ES6语法中let,const ,var的区别是什么下一篇:

11 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18