当前位置: 首页 > web >正文

服务器查日志太慢,试试grep组合拳

场景一:查异常堆栈,不能只看一行

Java异常堆栈通常都是多行的,仅仅用grep "NullPointerException"只能看到最上面那一行,问题根源在哪根本找不到
这个时候使用grep的-A(After)参数来显示匹配行之后的N行

# 查找NullPointerException,并显示后面的50行
grep -A 50 "java.lang.NullPointerException" a.log

如果发现异常太多,屏幕一闪而过,可以用less加上分页查看:

grep -A 50 "java.lang.NullPointerException" a.log | less

在less视图中,你可以:

1.使用上下箭头或者Page Up/Down键来上下滚动
2.输入G直接翻到末尾,方便快速查看最新的日志
3.输入/Exception继续搜索
4.按q键推出

场景二:实时看新日志怎么打印

如果你的应用正在运行,并且你怀疑它会随时抛出异常,你可以实时监控日志文件的增长。
使用tail -f 结合grep:

# 实时监控a.log文件的新增内容,并只是显示包含“java.lang.NullPointerException”的行及其后的50行
tail -f a.log | grep -A 50 "java.lang.NullPointerException"

只要异常一出现,它就会自动打印出来,堆栈信息也一并送到你面前,想停下来按ctrl+c,想更准确,加-i忽略大小写,防止大小写拼错找不到

场景三:翻历史日志or查看压缩日志

服务器上的日志一般都会按天或按大小分割压缩,变成.log.2025-07-28.gz这种格式,查找这种文件的异常信息怎么办?
1.查找当前目录所有.log文件:

# 在当前目录下查找所有以.log结尾的文件,-H参数可以顺便打印出文件名
grep -H -A 50 "java.lang.NullPointerException" *.log

其中-H会帮你打印出是哪个文件中出现的问题,防止找完还不知道是哪天的事
2.查找.gz文件(压缩日志):

zgrep -H -A 50 "java.lang.NullPointerException" *.gz

zgrep是专门处理.gz的grep,它的功能和grep完全一样,无需手动解压

场景四:统计异常数量(快速判断异常是否频繁)

有时候你需要知道某个异常到底出现了多少次,是偶发还是成灾,使用grep -c:

grep -c "java.lang.NullPointerException" a.log

如果你要统计所有日志里的数量:

grep -c "java.lang.NullPointerException" *.log

其他常用的grep参数

参数作用
-B N匹配行之前的N行(Before)
-A N匹配行之后的N行(After)
-C N匹配上下共N行(Context)
-i忽略大小写
-H显示匹配文件名
-r递归搜索目录下所有文件
http://www.xdnf.cn/news/16649.html

相关文章:

  • 时序数据库选型指南:工业大数据场景下基于Apache IoTDB技术价值与实践路径
  • 5 分钟上手 Firecrawl
  • 【办公类-109-01】20250728托小班新生挂牌(学号姓名)
  • API产品升级丨全知科技发布「知影-API风险监测平台」:以AI重构企业数据接口安全治理新范式
  • 企业级日志分析系统ELK
  • Pycaita二次开发基础代码解析:点距测量、对象层级关系与选择机制深度剖析
  • 基于DeepSeek大模型和STM32的矿井“围压-温度-开采扰动“三位一体智能监测系统设计
  • 边缘计算+前端实时性:本地化数据处理在设备监控中的响应优化实践
  • vue element 封装表单
  • STM32时钟源
  • GaussDB as的用法
  • 【氮化镓】GaN同质外延p-i-n二极管中星形与三角形扩展表面缺陷的电子特性
  • 力扣 hot100 Day58
  • LeetCode 2044.统计按位或能得到最大值的子集数目:二进制枚举/DFS回溯(剪枝)
  • 介绍一下static关键字
  • IP协议解析:从寻址到路由
  • MCP协议全景解析:从工业总线到AI智能体的连接革命
  • 【基础篇三】WebSocket:实时通信的革命
  • CDN架构全景图
  • 硕博电子大功率IO模块
  • opencv学习(轮廓检测)
  • 【论文阅读】Safety Alignment Should Be Made More Than Just a Few Tokens Deep
  • 微型化IMU如何突破无人机与机器人的性能边界?
  • 数据开源 | “白虎”数据集首批开源,迈出百万数据征途第一步
  • 医疗人工智能高质量数据集和语料库建设路径探析
  • linux安装zsh,oh-my-zsh,配置zsh主题及插件的方法
  • 3. Socket 编程 TCP
  • mp快速入门
  • 《LeetCode 热题 100》整整 100 题量大管饱题解套餐 中
  • 端到端的核心区别点