如何通过shell脚本查看k8s日志
导读:本文共1433.5字符,通常情况下阅读需要5分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: 查看日志:kubectl logs -f podName --tail 100比如我们如果想查指定的pod,指定行数,指定的内容,每次都需要输入kubectl logs -f xxx --tail yyy | grep zzz为了方便,可自定义脚本,输入sh .sh xxx yyy zzz即可,并且xxx支持RE;占位符的方式#!/bin/bash#kubec... ...
目录
(为您整理了一些要点),点击可以直达。查看日志: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,因此是脚本编码的问题。
2.命令中的grep
可以发现最终拼接出来的字符串,是一条正确的命令,但是通过${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”
</div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
如何通过shell脚本查看k8s日志的详细内容,希望对您有所帮助,信息来源于网络。