oracle 排查卡顿相关日志

都是 Oracle 数据库在 Automatic Diagnostic Repository (ADR) 机制下生成的 跟踪日志(Trace Files),但它们的来源、用途和内容各有不同。下面逐一详解:


✅ 1. xxxx_ora_68372.trc

🔹 类型:用户会话跟踪文件(User Session Trace)

🔍 命名解析:

  • xxxx:数据库实例名(SID)
  • ora:表示这是一个 Oracle 用户会话进程(非后台进程)
  • 68372:操作系统进程 ID(PID)

📌 来源:

  • 客户端连接数据库时启动的服务器进程(Server Process) 生成。
  • 本质上是一个通过 OCI 连接数据库的"用户会话",因此其 trace 文件以 _ora_ 命名。

📝 内容特点:

  • 记录该会话的 基本上下文信息(SESSION ID、MODULE NAME、ACTION 等)
  • 包含 操作的时间戳、命令类型(如 backup)、开始/结束时间
  • 不包含详细 SQL 执行计划或 SBT 调用细节(除非手动开启 SQL_TRACE)

✅ 2. xxxx_dia0_10319_lws_1.trc

🔹 类型:诊断守护进程(Diagnostic Daemon)生成的"本地等待链"日志

🔍 命名解析:

  • dia0Diagnostic Daemon(诊断守护进程),负责自动检测异常(如 hung session)
  • 10319:dia0 进程的 PID
  • lws_1Local Wait Chain Snapshot #1(本地等待链快照)

📌 来源:

  • 当 Oracle 的 Health Monitor (HM) 检测到某个会话长时间无响应(如等待超过阈值),会触发 dia0 进程生成 等待链分析(Wait Chain Analysis)
  • _lws_ 文件专门用于记录 会话之间的阻塞关系(谁在等谁)。

📝 内容特点:

  • 包含完整的 等待事件栈(Wait Event Stack)
  • 显示当前会话正在等待的资源(如 'recovery area: computing obsolete files'
  • 列出 前序等待事件 (如 'direct path write temp'
  • 可能包含 执行的 SQL 片段 (如 dbms_rcvman.lbCursor_t 调用)

✅ 3. xxxx_dia0_10319_base_2.trc

🔹 类型:诊断守护进程(dia0)的基础跟踪文件(Base Trace)

🔍 命名解析:

  • base_2:表示这是 dia0 进程的 第 2 个基础 trace 文件(可能因日志轮转产生多个)
  • _lws_ 不同,_base_ 文件记录 dia0 自身的运行状态和检测事件

📌 来源:

  • dia0 进程在执行 Health Monitor 任务时,会将通用日志写入 base_*.trc
  • 包括:hung session 检测、I/O 异常告警、自动诊断动作等

📝 内容特点:

  • 记录 hung session 的发现与解除时间 log

    复制代码
    HM: Session ... is hung
    HM: Session ... is no longer hung
  • 报告 系统级异常 ,如:log

    复制代码
    HM: IO load is abnormally high - 33% outliers
  • 触发 本地等待链分析 (即生成 _lws_*.trc 的原因)


📊 三者关系总结

表格

文件 生成者 作用 关键信息
xxxx_ora_68372.trc 会话进程 记录 操作生命周期 会话 ID、操作类型、起止时间
xxxx_dia0_10319_lws_1.trc dia0(Health Monitor) 分析卡住会话的等待链 等待事件、SQL 上下文、I/O 行为
xxxx_dia0_10319_base_2.trc dia0(Health Monitor) 记录诊断事件和系统告警 hung session 状态变化、I/O 异常

💡 附加说明:如何查看这些文件?

所有文件均位于 ADR 的 trace 目录下:

复制代码
 $ ORACLE_BASE/diag/rdbms/siphisdb/siphisdb/trace/

可通过以下 SQL 查询路径:

复制代码
SELECT VALUE FROM V $ DIAG_INFO WHERE NAME = 'Diag Trace';

✅ 总结

表格

文件 是什么日志? 能回答什么问题?
xxxx_ora_68372.trc 会话日志 "哪个会话执行了什么操作?何时开始/结束?"
xxxx_dia0_10319_lws_1.trc 等待链分析日志 "会话卡在哪里?在等什么资源?执行了什么代码?"
xxxx_dia0_10319_base_2.trc 健康监控日志 "系统是否检测到异常?I/O 是否过载?卡顿是否持续?"

这三份日志共同构成了完整的故障诊断证据链,是排查卡顿问题的关键依据。

相关推荐
wuxi_joe5 小时前
一家研发制造企业的“软件进化史”
大数据·数据库·制造
草莓熊Lotso5 小时前
远程控制软件实测!2026年1月远程软件从“夯”到“拉”全功能横评
运维·服务器·数据库·人工智能
冰暮流星5 小时前
sql之删除与软删除
数据库·sql
沐雪架构师5 小时前
LangChain 1.0 记忆管理:短期与长期记忆详解
服务器·数据库·langchain
电商API&Tina5 小时前
唯品会获得vip商品详情 API 返回值说明
java·大数据·开发语言·数据库·人工智能·spring
爱学习的阿磊5 小时前
Python深度学习入门:TensorFlow 2.0/Keras实战
jvm·数据库·python
m0_736919105 小时前
构建一个桌面版的天气预报应用
jvm·数据库·python
ctyshr5 小时前
实战:用OpenCV和Python进行人脸识别
jvm·数据库·python
一起养小猫8 小时前
Flutter for OpenHarmony 实战:打造天气预报应用
开发语言·网络·jvm·数据库·flutter·harmonyos