shell脚本查看k8s日志介绍
目录
- 占位符的方式
- 指定参数 getopts
- 问题
- 1.执行 shell 脚本\r问题
- 2.命令中的grep
查看日志:kubectl logs -f podName --tail 100
比如我们如果想查指定的pod,指定行数,指定的内容,
每次都需要输入kubectl logs -f xxx --tail yyy | grep zzz
为了方便,可自定义脚本,输入sh .sh xxx yyy zzz即可,并且xxx支持RE;
占位符的方式
#!/bin/bash
# kubectl get pods
#notification
x="kubectl logs -f"
y="--tail"
g="|grep"
name=`kubectl get pods | grep ^$1 | awk '{print $1}'`
x="eval $x $name $y $2 $g $3"
${x}
# sh log.sh podName 20 content
# 最终:kubectl logs -f podName --tail 20 | grep content
指定参数 getopts
#!/bin/bash
# ":":如果某个选项(option)后面出现了冒号(":"),则表示这个选项后面可以接参数
x="kubectl logs -f"
y="--tail"
g="|grep"
while getopts ":n:f:c:" opt
do
case $opt in
n)
name=`kubectl get pods | grep ^$OPTARG | awk '{print $1}'`
x="$x $name"
;;
f)
x="$x $y $OPTARG"
;;
c)
x="$x $g $OPTARG"
;;
?)
echo "未知参数"
exit 1;;
esac
done
x="eval $x"
${x}
# sh log.sh -n podName -f 20 -c content
# 最终:kubectl logs -f podName --tail 20 | grep content
问题
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”

您可能感兴趣的文章
- 01-12Docker部署rabbitmq遇到的两个问题
- 01-12最新虚拟机VMware 14安装教程
- 01-12使用docker compose安装harbor私有仓库的详细教程
- 01-12Windows下Docker安装各种软件的详细过程
- 01-12seata docker 高可用部署的详细介绍
- 01-12浅谈Tomcat多层容器的设计
- 01-12Gogs+Jenkins+Docker 自动化部署.NetCore的方法步骤
- 01-12解决vscode docker插件docker.socket权限问题
- 01-12Docker中运行PostgreSQL并推荐几款连接工具
- 01-12Docker核心原理之 Cgroup详解


阅读排行
推荐教程
- 12-07一文教你怎么选择Tomcat对应的JDK版本
- 12-23linux中ftp无法访问怎么办
- 12-11docker存储目录迁移示例教程
- 12-10docker start启动容器后仍然exit状态的解决
- 12-10Linux下如何安装Logstash
- 12-05Docker安装Jenkins全过程
- 01-05Shell脚本去重的几种方法实例
- 12-22kvm虚拟机配置NAT端口转发的实现方法
- 12-19Zabbix SAML SSO 登录绕过漏洞的操作流程
- 12-15Docker-Compose搭建Spark集群的实现方法




