树叶云OceanBase教程:OceanBase SQL Trace

SQL Trace 能够交互式的提供上一次执行的 SQL 请求执行过程信息及各阶段的耗时。

SQL Trace 开关

SQL Trace 功能默认是关闭的,可通过 session 变量来控制其打开和关闭。

  • 打开 SQL Trace 功能的语句如下:
    obclient>SET ob_enable_trace_log = 1;
  • 关闭 SQL Trace 功能的语句如下:
    obclient>SET ob_enable_trace_log = 0;

Show Trace

当 SQL Trace 功能打开后,执行需要诊断的 SQL,然后通过 ​SHOW TRACE​ 能够查看该 SQL 执行的信息。这些执行信息以表格方式输出,每列说明如下:

列名

说明

Title

记录执行过程某一个阶段点

KeyValue

记录某一个阶段点产生的一些执行信息

Time

记录上一个阶段点到这次阶段点执行耗时(us)

示例

  1. 打开 SQL Trace:
    obclient> SET ob_enable_trace_log = 1;
  2. 执行目标 SQL:
    obclient> CREATE TABLE t1(c1 INT,c2 INT,c3 INT); 
    Query OK, 0 rows affected (0.02 sec) 
    
    obclient> INSERT INTO t1 VALUES(1,1,1); 
    Query OK, 1 rows affected (0.02 sec) 
    
    obclient> INSERT INTO t1 VALUES(2,2,2); 
    Query OK, 1 rows affected (0.02 sec) 
    
    obclient>SELECT * FROM t1 WHERE c1 = 1; 
    +----+------+------+ 
    | c1 |  c2  |  c3  | 
    +----+------+------+ 
    | 1  |  1   |   1  |
    +----+------+------+
  3. 显示 Trace:
  4. obclient> SHOW TRACE; 
    +------------------------------+---------------------------------------------------------------------------------------------------+ 
    | TITLE | KEYVALUE | TIME | 
    +------------------------------+----------------------------------------------------------------------------+------+ 
    | process begin | in_queue_time:17, receive_ts:1612420489580707, enqueue_ts:1612420489580709 | 0 | 
    | query begin | trace_id:YB42AC1E87E6-0005B8AB2D57844F | 1 | 
    | parse begin | stmt:"set ob_enable_trace_log = 1", stmt_len:27 | 62 | 
    | pc get plan begin | NULL | 9 | 
    | pc get plan end | NULL | 19 | 
    | transform_with_outline begin | NULL | 1 | 
    | transform_with_outline end | NULL | 31 | 
    | resolve begin | NULL | 21 | 
    | resolve end | NULL | 33 | 
    | execution begin | arg1:false, end_trans_cb:false | 14 | 
    | start_auto_end_plan begin | NULL | 39 | 
    | start_auto_end_plan end | NULL | 1 | 
    | execution end | NULL | 11 | 
    | query end | NULL | 39 | 
    +------------------------------+---------------------------------------------------------------------------------------------+------+
      示例中 ​
      SHOW TRACE​ 结果说明如下:

    • Title 列包含整个 SQL 执行经历的各个阶段的信息以及该 SQL 真实的执行路径。上述示例的结果中有经过 Resolve、Transform、Optimizer 和 Code Generate 四个流程,说明该 SQL 重新生成了计划,没有命中 plan cache。
    • KeyValue 列包含一些执行信息,可以用于排查问题:
      • trace_id​ 可以作为 sql_audit 中的过滤条件,快速找到该 SQL 执行信息,同时也可以通过该 ​trace_id​ 快速查找相关的 observer 日志。
      • plan_id​ 可以用于在 ​v$plan_cache_plan_explain​ 中查看 plan cache 中缓存的具体执行计划。
      • phy_plan_type​ 指出该次执行计划的类型(1 表示本地计划/2 表示远程计划/3 表示分布式计划),可以辅助 SQL 诊断。
    • Time 列显示上一个阶段点到这次阶段点执行耗时。例如,resolve end 对应的 206 us 表示的是 resolve begin 到 resolve 耗时。如果某个 SQL 执行很慢,则通过查看 time 列,能够快速定位出具体是哪个阶段执行较慢,然后再进行具体分析。此例中,执行耗时主要在生成计划过程中,因此只需要分析没有命中 plan cache 的原因,可能是计划淘汰后 第一次执行该 SQL,或是 plan cache 不支持的 SQL。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/230997.html<

(0)
运维的头像运维
上一篇2025-04-19 12:06
下一篇 2025-04-19 12:08

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注