Shell grep 命令扩展增强
背景: 线上排查问题需要找出有某个特征的日志,并获取这些日志的完整调用日志链路。
比如, 通过某个tag 获取到了这些日志的 请求id 【Span ID】,
cat xxxx.log | grep '某tag' | awk -F '某tag' '{print $2}'
然后还需要再一步取得所有SpanId的完整日志链。显然目前我们需要使用 xargs 来批处理执行。 但这里有个问题。 grep 无法支持这种用法。
如下:
[localhost ~]$ cat xxxxxx.log | grep '某tag' | awk -F '某tag' '{print $2}' | xargs grep xxxxxx.log grep: 某SpanId: No such file or directory
grep 第一个参数必须是 关键词正则 ,其后跟随文件路径。
所以为了解决这个问题,我们需要使用一个改造后的SHELL脚本,这里命名为 grepx ,用于增强 grep 命令:
#!/bin/bash FILE_PATH="$1*" COUNT=0 while [ $# -gt 0 ] do if [ $COUNT -gt 0 ] then grep "$1" $FILE_PATH #输出空白行用来隔断日志 echo -e "\n\n" fi #shift命令用于对参数的移动(左移),通常用于在不知道传入参数个数的情况下,依次遍历每个参数 shift let COUNT=COUNT+1 done
原理是对调参数位置, 再通过 shift 命令移动参数,批量读取管道传递过来的参数,或者 控制台传递的参数。
然后 shell 脚本便可以写成如下:
cat xxxxxx.log | grep '某tag' | awk -F '某tag' '{print $2}' | xargs ~/grepx xxxxxx.log
完美搞定。
PS:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架