【Linux】Java线上问题,一分钟日志定位

  • 1. 查看异常堆栈
  • 2. 实时叮新日志
  • 3. 翻历史/压缩日志
  • 4. 统计异常数量
  • 5. 多种异常一起查
  • 6. 反向过滤
  • 7. 同时满足多个关键字查询
  • 8. 定位最近一次异常
  • 9. 异常排行榜

1. 查看异常堆栈

# 在 a.log 文件中查找包含 NullPointerException 的行,并显示该行以及其后的 50 行,然后通过分页工具 less 逐页查看结果。
grep -n -A 50 "NullPointerException" a.log | less
[root@iv-ye20h65dz45i3z346rvs ~]# grep -n -A 50 "Exception" log.out | less 

在这里插入图片描述

2. 实时叮新日志

应用到的场景:应用在跑随时可能抛异常

tail -f log.out | grep -n -A 50 "Exception" 

1️⃣ tail -f log.out

  • tail:查看文件的结尾部分。
  • -f:表示 follow,即“跟随”文件内容的变化。
  • 当 log.out 文件新增内容时,会实时输出新增内容到终端。

2️⃣ | grep -n -A 50 “Exception”

  • |:管道,把 tail -f 输出的内容传给 grep。

grep -n -A 50 “Exception”:

  • -n:显示匹配行的行号。
  • -A 50:显示匹配行之后的 50 行内容。
  • “Exception”:匹配的关键字。

3. 翻历史/压缩日志

老日志切分打包,照样可以查

[root@iv-ye20h65dz45i3z346rvs ~]# grep -n -H -A 50 "Exception" log.out

在这里插入图片描述

  • -n:显示匹配行的 行号。
  • -H:显示匹配行的 文件名。 在只搜索一个文件时效果不明显,但如果同时搜索多个文件,会显示是哪一个文件匹配的。
  • -A 50:显示匹配行 之后的 50 行 内容。
  • “Exception”:要搜索的关键字。
  • log.out:要搜索的文件。

zgrep -n -H -A 50 "Exception" log.out.gz

在这里插入图片描述

4. 统计异常数量

统计异常数量用于区分是偶发还是高频错误

grep -c "Exception" log.out[root@iv-ye20h65dz45i3z346rvs ~]# grep -c "Exception" log.out
6

5. 多种异常一起查

[root@iv-ye20h65dz45i3z346rvs ~]# grep -n -A 50 -E "NullPointerException|JSONException" log.out

在这里插入图片描述

6. 反向过滤

grep -n -A 20 "JSONException" log.out | grep -v "ERROR"

在这里插入图片描述

  • 从 log.out 中找到所有包含 JSONException 的行及其后 20 行。
  • 过滤掉其中包含 “ERROR” 的行。
  • 输出剩余行,带行号。

7. 同时满足多个关键字查询

[root@iv-ye20h65dz45i3z346rvs ~]# grep "Exception" log.out | grep "JSONException"
cn.hutool.json.JSONException: Unclosed tag html at 265 [character 162 line 6]
cn.hutool.json.JSONException: Unclosed tag html at 265 [character 162 line 6]
cn.hutool.json.JSONException: Unclosed tag html at 265 [character 162 line 6]
cn.hutool.json.JSONException: Unclosed tag html at 265 [character 162 line 6]
cn.hutool.json.JSONException: Unclosed tag html at 265 [character 162 line 6]
cn.hutool.json.JSONException: Unclosed tag html at 265 [character 162 line 6]

8. 定位最近一次异常

[root@iv-ye20h65dz45i3z346rvs ~]# tac log.out | grep -m 1 "Exception" -A 20
cn.hutool.json.JSONException: Unclosed tag html at 265 [character 162 line 6]
2025-08-19 11:18:31.448 [Thread-5] ERROR c.a.i.k.g.r.e.ExtractRpcImpl - 关系抽取请求异常,modelName:通用关系及属性抽取模型,requestBody:{"contents":[{"code":"1bf670f4aa39455c916ae2ed20d8b08a","text":"那孩子是张兴旺和刘巧云生的"}]}
2025-08-19 11:18:31.445 [Thread-5] INFO  c.a.i.k.g.r.e.ExtractRpcImpl - 关系抽取请求,taskCode:5aa931fc89e7404e85e675e8dde68d53 code:1455627b16fe4643a0aaa067a7af947e modelName:通用关系及属性抽取模型 请求地址:http://10.208.61.198:38128/api/v2/re/get_relation/batch requestBody:{"contents":[{"code":"1bf670f4aa39455c916ae2ed20d8b08a","text":"那孩子是张兴旺和刘巧云生的"}]}
Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@4d88f6c6]
<==    Updates: 1
==> Parameters: 1455627b16fe4643a0aaa067a7af947e(String), 5aa931fc89e7404e85e675e8dde68d53(String), 1(Integer), 32(Integer), 2600032(Integer), null
==>  Preparing: INSERT INTO data_import_status ( task_code, history_code, status, sum_size, done_size, create_time ) VALUES ( ?, ?, ?, ?, ?, ? )
JDBC Connection [com.alibaba.druid.pool.DruidStatementConnection@251360d8] will not be managed by Spring
SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@4d88f6c6] was not registered for synchronization because synchronization is not active
Creating a new SqlSessionat java.lang.Thread.run(Thread.java:748)at cn.ac.ict.knowledge.graph.service.extract.ExtractTaskServiceImpl.lambda$syncExecuteTask$21(ExtractTaskServiceImpl.java:1062)at cn.ac.ict.knowledge.graph.service.extract.ExtractTaskServiceImpl.executeTask(ExtractTaskServiceImpl.java:996)at cn.ac.ict.knowledge.graph.service.extract.ExtractTaskComponent.relationExtract(ExtractTaskComponent.java:289)at cn.ac.ict.knowledge.graph.service.extract.ExtractTaskComponent.extractRelationAndMysql(ExtractTaskComponent.java:610)at cn.ac.ict.knowledge.graph.rpc.extract.ExtractRpcImpl.extractRelation(ExtractRpcImpl.java:77)at cn.hutool.json.JSONUtil.toBean(JSONUtil.java:461)at cn.hutool.json.JSONUtil.toBean(JSONUtil.java:475)at cn.hutool.json.JSONUtil.parse(JSONUtil.java:227)at cn.hutool.json.JSONUtil.parseObj(JSONUtil.java:112)at cn.hutool.json.JSONObject.<init>(JSONObject.java:187)

在这里插入图片描述


在这里插入图片描述

9. 异常排行榜

 grep "Exception" log.out | sort | uniq -c | sort -nr | head
  • 找出日志中所有包含 “Exception” 的行。
  • 按行内容统计每种异常出现的次数。
  • 按出现次数从高到低排序。
  • 显示出现次数最多的前 10 条异常记录。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/96755.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/96755.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/96755.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

智慧农业温室大棚远程监控物联网系统解决方案

一、方案背景与目标随着现代农业向智能化、精准化转型&#xff0c;传统温室大棚管理面临效率低、响应慢、成本高等痛点。本方案通过部署御控农业物联网系统&#xff0c;实现温室环境参数实时监测、设备远程控制、数据智能分析及预警决策&#xff0c;助力农户降低人工成本&#…

【剖析高并发秒杀】从流量削峰到数据一致性的架构演进与实践

一、 挑战&#xff1a;三高背景下的数据库瓶颈秒杀场景的核心挑战可以归结为“三高”&#xff1a;高并发、高性能、高可用。而系统中最脆弱的一环&#xff0c;往往是我们的关系型数据库&#xff08;如MySQL&#xff09;。它承载着最终的数据落地&#xff0c;其连接数、IOPS和CP…

Redisson最新版本(3.50.0左右)启动时提示Netty的某些类找不到

文章目录一、写在前面二、解决方案1、解决方案2、一劳永逸3、确定redisson依赖netty的版本一、写在前面 Redisson最新版本&#xff0c;大概3.47.0&#xff0c;在JDK8环境下&#xff08;实测JDK17也一样&#xff09;会提示Netty的某些类找不到&#xff1a; Exception in threa…

MTK Linux DRM分析(八)- KMS drm_crtc.c

一、简介 Linux DRM(Direct Rendering Manager)子系统是内核中管理图形硬件的核心组件,而 CRTC(CRT Controller)又是其中的关键之一。它起源于过去控制阴极射线管(CRT)显示器的控制器概念,如今在现代图形显示中依旧扮演着至关重要的角色。 可以把 CRTC 想象成图形显示…

vue+openlayers示例:适配arcgis矢量瓦片服务以及样式(附源码下载)

由于单位这边有个项目是基于openlayers地图引擎框架实现webgis地图可视化功能&#xff0c;但是要调用第三方的arcgis矢量瓦片服务以及适配样式&#xff0c;在这个背景下&#xff0c;基于openlayersvue实现适配arcgis矢量瓦片服务以及样式效果&#xff0c;适合学习openlayers与前…

mybatis xml中表名 字段报红解决

mybatis xml中表名 字段报红解决

谷歌浏览器重定向url,谷歌浏览器浏览网页修改url到本地

谷歌应用商店搜索插件requestly&#xff08;有个相似名称的插件&#xff0c;选择这个Requestly: Supercharge your Development & QA&#xff09; 安装后打开插件网址https://app.requestly.io/rules/my-rules 新建规则rules->my rules-> new rule -> redirect …

教育场景下禁用html5播放器拖动进度条的例子

禁用视频课程进度条的拖动功能&#xff0c;主要是为了强制学员按照课程设计的顺序观看内容&#xff0c;防止跳过关键知识点&#xff0c;从而保证学习效果和课程的完整性。 1.防止应试作弊&#xff1a; 在一些需要观看视频才能解锁下一章节或完成测试的场景中&#xff0c;禁用…

async实战

一、协程 协程是程序员人为创造 协程是一种用户态内的上下文切换技术。通过一个线程实现代码块相互切换执行。yield返回生成器 yield from 代表&#xff0c;跳到 func2协程函数 通过函数名()&#xff0c;是执行不了的。需要把函数加入到loop里面来&#xff0c;才可以被执行。 把…

个人搭建小网站教程(云服务器Ubuntu版本)

目录 1.配置云服务器&#xff08;略讲&#xff09; 2.vscode连接&#xff08;ssh连接&#xff09; 3.本地压缩项目包 4.传输项目 5.配置项目依赖 6.运行项目 1.启动 FastAPI 后端&#xff08;Python 部分&#xff09; 2.启动 Next.js 前端&#xff08;Node.js 部分&…

pion/webrtc v4.1.4 版本发布:关键特性与性能优化全面解析

引言 实时通信技术在现代互联网应用中扮演着越来越重要的角色&#xff0c;从视频会议到在线教育&#xff0c;从远程医疗到物联网设备交互&#xff0c;WebRTC技术已经成为实时音视频通信的事实标准。作为Go语言中最成熟且广泛使用的WebRTC实现&#xff0c;pion/webrtc项目持续推…

集成算法(聚类)

下面简单集成算法代码from sklearn.datasets import make_blobs from sklearn.cluster import KMeans import matplotlib.pyplot as plt# 创建数据集&#xff0c;生成 3 个中心的聚类数据&#xff0c;共 300 个样本&#xff0c;每个样本 2 个特征 X, _ make_blobs(n_samples30…

01 网络信息内容安全--绪论

1 课程内容 网络信息内容获取技术网络信息内容预处理技术网络信息内容过滤技术社会网络分析技术入侵检测技术异常流量检测技术对抗攻击技术 2 理论研讨 分为16个组 2.1 网络信息内容获取技术&#xff1a;第1组 【用DeepSeek网站爬虫&#xff0c;数据获取零成本&#xff01…

GPT-5:天变了吗?还是风停了?

2025年8月8日&#xff0c;OpenAI 发布了 GPT-5。这次更新被许多人寄予厚望&#xff0c;也引发了不少争议。对普通用户来说&#xff0c;这是一场“又快又会做事”的智能盛宴&#xff1b;而对资深开发者和 AI 研究者而言&#xff0c;GPT-5 可能更像是一次不够激进、略显保守的版本…

生信分析自学攻略 | R语言数据筛选和修改

在《生信小白自学攻略》系列的前几篇文章中&#xff0c;我们已经了解了 R 和 RStudio 的安装、RStudio 的深度探索&#xff0c;以及 R 语言的基本数据类型和数据结构。现在&#xff0c;是时候深入探讨如何运用 R 语言对数据进行精细化处理了。本篇推文将详细介绍如何在 R 中对数…

从零开始学习概念物理(第13版)(1)

前言&#xff1a;对我来说&#xff0c;最有用的就是物理了&#xff0c;尤其是电磁学。但是要学好它&#xff0c;我得夯实我的基础&#xff0c;前面更加基础的数学和物理都不能拉下。现在我问了Deepseek推荐的国外物理书&#xff0c;这本《概念物理》是最适合我&#xff0c;等入…

CSS变量

元素背景需要统一&#xff0c;一个个设置修改起来很麻烦&#xff0c;也没有全局变量&#xff1f; CSS中的变量_css变量-CSDN博客 -- 前缀定义变量&#xff0c;var(--) 使用变量&#xff0c;:root 表示根元素。 :root { --bg:#222; --fg:#bbb; } body { background:var(--bg)…

C++(Qt)软件调试---vscode配置clang-tidy静态分析(30)

C(Qt)软件调试—vscode配置clang-tidy静态分析&#xff08;30&#xff09; 文章目录C(Qt)软件调试---vscode配置clang-tidy静态分析&#xff08;30&#xff09;[toc]1 概述2 clang-tidy基本用法3 目前已有检查项4 vscode配置clang-tidy5 .clang-tidy配置文件6 参考地址更多精彩…

每天自动备份oracle

oracle数据库比其他数据库都贵&#xff0c;但是自带的管理工具却很差&#xff0c;真不知道咋想的。想完成每天自动备份&#xff0c;只能自己动手(window环境)&#xff1a;1、创建个备份目录&#xff0c;如D:\databack2、创建个脚本&#xff1a;backup.bat核心内容如下&#xff…

HBase Coprocessor:扩展HBase功能的利器

HBase Coprocessor&#xff1a;扩展HBase功能的利器 关键词&#xff1a;HBase, Coprocessor, 协处理器, RegionServer, 分布式计算, 扩展功能, 二级索引 摘要&#xff1a;HBase作为Hadoop生态中的分布式列存储数据库&#xff0c;以高可靠性、高吞吐量和强一致性著称&#xff0c…