Form_通过Trace分析Concurrent和Form性能和异常详解(案例)

简介: 2014-06-21 Created By BaoXinjian 一、摘要 1. 理论概念 (1). 优化器选择方式:基于Rule和基于Cost,在数据库层次进行设定 (2). 执行计划解读:解析 -> 执行 -> 提取 (3).

2014-06-21 Created By BaoXinjian

一、摘要


1. 理论概念

(1). 优化器选择方式:基于Rule和基于Cost,在数据库层次进行设定

(2). 执行计划解读:解析 -> 执行 -> 提取

(3). 执行效能解析:每个动作CPU和时间,提取的次数

(4). Trace的4中方式:Trace: 常规的Trace,这种所有里面SQL的变量都被Bind Variable替代,适合性能分析;

                              Trace With Binds: 带变量值得Trace, 这种Trace的结果中带具体的值,适合问题查询;

                              Trace With Waits:

                              Trace With Binds and Waits:

(5). TkProf工具:将trc文件替换成prf文件,整理后比较容易阅读,但是SQL的执行顺序和一些信息会丢失

(6). 最终的Trace文件会呈现具体的SQL语句和每个SQL语句对应的效率如下

2. 并发程式Trace

(1).通过Request中enable trace去启动Trace功能;

        i. 产生的是Regular Trace,里面不带参数值

        ii.启动方式:调用Request是点击Enable选项

(2).通过Profile去启动单个用户下所有的Trace功能;

        i. 产生的是Trace With Binds,带参数

        ii.启动方式:a. Request的Trace Enable选项并无启动 

                    b. 修改这个User层级下的Profiler<Initialization SQL Statement - Custom>, 单行格式

                                                    begin

                                                        fnd_ctl.fnd_sess_ctl('', '','TRUE','TRUE','LOG','ALTER SESSION SET

                                                                                        EVENTS=''10046 TRACE NAME CONTEXT FOREVER, LEVEL 4''

                                                                                        TRACEFILE_IDENTIFIER=''<tar/bug#>''');

                                                     end;

                                    

         iii.重要的参数

            LEVEL 4 可被改为LEVEL 8 或者LEVEL 12,其意义分别如下:
            Use LEVEL 4 :以”Trace with Binds” 的方式进行Trace
            Use LEVEL 8 :以”Trace withWaits” 的方式进行Trace
            Use LEVEL 12 :以”Trace with Binds and Waits” 的方式进行Trace    

(3).通过SQL去启动所有用户下所有的Trace功能;

        i. 产生的Trace With Binds, 带参数

        ii.启动方式:a. 调用数据库系统级的Event 10046

                    b. 需要调用一段特定的SQL<bde_session_event_10046.sql>

                    c. 产生SQL之后再调用这段SQL,再关闭所有User的Trace

3. Form表单的Trace

(1). 使用诊断功能,启动Form的Trace with binds

(2). 进行具体操作时,其记录会产生至Trace文件中

(3). 产生Trace文件后,关闭Trace with binds

4. 非常重要的注意事项

当trace调试后,必须进行关闭,特别是在PROD环境,不然如果不关闭,User的任何操作系统会一直记录trace,会对服务器造成非常大的负担

之前在项目中就遇到被DBA Team抱怨,所以一个好的习惯非常重要

当然经常运行SQL去查询Concurrent Program是否启动trace选项做个后期预防也重要

 

二、案例分析 - Concurrent Trace 分析


案例:对Invoice History Report进行Trace分析,了解其执行效率

Step1. 在并发程式设定Enable Trace为True

Step2. 调用该程式,并记录RequestID(5820613),并根据这个ID追踪具体阐述Trace位置

Step3. 执行如下SQL,查询Trace文件名和路径

 1 SELECT   'Request id: ' || Request_Id,
 2          'Trace id: ' || Oracle_Process_Id,
 3          'Trace Flag: ' || Req.Enable_Trace,
 4             'Trace Name:'
 5          || Dest.VALUE
 6          || '/'
 7          || LOWER (Dbnm.VALUE)
 8          || '_ora_'
 9          || Oracle_Process_Id
10          || '_APPS.trc',
11          'Prog. Name: ' || Prog.User_Concurrent_Program_Name,
12             'File Name: '
13          || Execname.Execution_File_Name
14          || Execname.Subroutine_Name,
15             'Status : '
16          || DECODE (Phase_Code, 'R', 'Running')
17          || '-'
18          || DECODE (Status_Code, 'R', 'Normal'),
19          'SID Serial: ' || Ses.Sid || ',' || Ses.Serial#,
20          'Module : ' || Ses.Module
21   FROM   Fnd_Concurrent_Requests Req,
22          V$session Ses,
23          V$process Proc,
24          V$parameter Dest,
25          V$parameter Dbnm,
26          Fnd_Concurrent_Programs_Vl Prog,
27          Fnd_Executables Execname
28  WHERE       Req.Request_Id = 5820613
29          AND Req.Oracle_Process_Id = Proc.Spid(+)
30          AND Proc.Addr = Ses.Paddr(+)
31          AND Dest.Name = 'user_dump_dest'
32          AND Dbnm.Name = 'db_name'
33          AND Req.Concurrent_Program_Id = Prog.Concurrent_Program_Id
34          AND Req.Program_Application_Id = Prog.Application_Id
35          AND Prog.Application_Id = Execname.Application_Id
36          AND Prog.Executable_Id = Execname.Executable_Id

 Step4. 获取Trace文件路径名为

Step5. 通过Tkporf工具将trc文件进行格式转化为prf格式

Step6. 查看prf文件

Step7. 如下即可看到最终的trace分析文件,该文件记录的在运行Request时所使用了那些SQL和对应的效率

 

三、案例分析 - Form Trace 分析


案例:对标准Invoice Form启动Trace分析

Step1. 启动Trace with Binds

Step2. 在这个过程建立Invoice并保存

Step3. 关闭Trace with Binds

Step4.系统会自动将Trace启动和关闭之间所有业务的操作记录下来保存在Trace文件中

获取路径SQL: SELECT value FROM v$parameter WHERE name = 'user_dump_dest'; 

注意:所以当调试后,关闭Trace功能非常重要,因为你不关闭trace功能,系统会一直记录操作记录,会对服务器造成很大的负担

 

Thanks and Regards

ERP技术讨论群: 288307890
技术交流,技术讨论,欢迎加入
Technology Blog Created By Oracle ERP - 鲍新建
相关文章
|
8月前
|
JSON Java 数据格式
有关Java调用第三方接口【Content-type为form-data】的示例代码
有关Java调用第三方接口【Content-type为form-data】的示例代码
379 0
|
3月前
|
Java
【编程基础知识】《Java 基础探秘:return、break、continue、label、switch 与 enum 的深度解析》
本文深入解析了 Java 中的 return、break、continue、label、switch 和 enum 等基础概念,通过代码示例和流程图,帮助读者理解这些控制结构和枚举类型在编程中的应用,提升编程能力。
34 3
|
4月前
|
BI API
Form 中调用并发请求生成报表并输出PDF的方法
【9月更文挑战第11天】该文档介绍了在表单中通过并发请求生成报表并将其输出为PDF的方法,包括设置并发请求、配置输出选项、触发请求及处理结果。具体步骤涉及创建请求、配置参数、设置输出类型为PDF、添加触发按钮、调用请求API、等待请求完成、获取并显示PDF文件。需根据所用系统和技术调整实现细节。
|
5月前
|
IDE Java 开发工具
Java系统中的错误码设计问题之错误消息的document link部分如何解决
Java系统中的错误码设计问题之错误消息的document link部分如何解决
20 0
|
6月前
|
消息中间件 调度 Android开发
Android经典面试题之View的post方法和Handler的post方法有什么区别?
本文对比了Android开发中`View.post`与`Handler.post`的使用。`View.post`将任务加入视图关联的消息队列,在视图布局后执行,适合视图操作。`Handler.post`更通用,可调度至特定Handler的线程,不仅限于视图任务。选择方法取决于具体需求和上下文。
71 0
|
8月前
|
移动开发 安全 数据安全/隐私保护
class dump使用方式和原理
class dump使用方式和原理
46 0
|
移动开发 安全 数据安全/隐私保护
class dump使用方式和原理
导出的包是经过混淆,经过加固比较安全的包了
|
设计模式 消息中间件 监控
Java Review - 使用Event Bus实现目录变化的监控
Java Review - 使用Event Bus实现目录变化的监控
125 0
|
前端开发 编译器 C#
.NET MVC第六章、@Html.Partial[ˈpɑːʃl](string name)分布视图
.NET MVC第六章、@Html.Partial[ˈpɑːʃl](string name)分布视图
160 0
.NET MVC第六章、@Html.Partial[ˈpɑːʃl](string name)分布视图
|
SQL 数据库
SQL*Net message from client 事件产生的原因分析
今天同事在做数据库巡检时,发现巡检报告中有大量的SQL*Net message from client等待事件。同事问什么情况下回产生SQL*Net message from client,为什么回产生SQL*Net message from client。
1691 0