10046event漫步
来源:互联网 发布:怎么用逆矩阵解方程组 编辑:程序博客网 时间:2024/04/28 00:32
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 728x15, 创建于 08-4-23MSDN */google_ad_slot = "3624277373";google_ad_width = 728;google_ad_height = 15;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
10046event漫步:
如果你对oracle性能调优很感兴趣或者比较专长,那么你对oracle的10046事件一定不会陌生。10046event是oracle用于系统性能分析时的一个最重要的事件。当激活这个事件后,将通知oraclekernel追踪会话的相关即时信息,并写入到相应trace文件中。这些有用的信息主要包括sql是如何进行解析,绑定变量的使用情况,会话中发生的等待事件等
10046event可分成不同的级别(level),分别追踪记录不同程度的有用信息。对于这些不同的级别,应当注意的是向下兼容的,即高一级的trace信息包含低于此级的所有信息。
?
10046event的追踪级别大致有:
level1:跟踪sql语句,包括解析、执行、提取、提交和回滚等。
level4:包括变量的详细信息
level8:包括等待事件
level12:包括绑定变量与等待事件
其中,level1相当于打开了sql_trace
?
10046event的启用和关闭:
前提条件:(先确保要event的会话环境符合条件)
1、?必须确保timed_statistics为TRUE,这个参数可以在会话级上进行修改。
2、?为了确保trace输出能够完整进行,还要调整此会话对trace文件大小的限制,一般将此限制取消,即将max_dump_file_size设置为UNLIMITED,或者设置为一个很大的阙值。
在满足了上述条件后,就可以启用10046event对会话进行后台跟踪了。
?
这里还有几种方式来启用10046event:
一种是在当前会话启用event,可以利用altersession+事件名称+level,
如:sql>altersessionsetevent‘10046tracenamecontextforever,level12’;
?
另外一种是启用别的会话进行event跟踪,可以利用oracle提供的dbms_system来完成。
如:sql>execdbms_system.set_ev(sid,serial#,10046,12,’’);
?
注意:
sql>execdbms_system.set_sql_trace_in_session(sid,serial#,true);
相当于打开了sql_trace。
?
event的关闭:
可以在通过下面的语句来关闭当前会话的event:
sql>altersessionsetevent‘10046tracenamecontextoff’;
?
也可以利用dbms_system包来关闭某个会话的event:
sql>executedbms_system.set_ev(sid,serial#,0,’’);
?
这里应当值得一提的是,TRACE将消耗相当的系统资源,因此我们在使用TRACE的时候应当慎重。对于正式的系统,应当只在必要的时候进行TRACE操作,并且应当及时关闭。
?
?
当利用事件trace完当前或某个session后,接下来我们的工作就是找到oracle生成的trace了。的初始化文件中user_dump_dest参数的设置将决定trace文件的生成位置。
?
从trace文件中查找和发现有用的信息,然后寻找必要的性能调整点并进行相应的调整:
大部分情况下,通过10046事件trace到文件里的信息包含了此会话中存在的性能问题,可以根据trace到的等待事件、SQL语句执行情况以及绑定变量的使用情况来进行分析和查找。
?
oracle提供了一个工具tkprof来对trace文件进行格式的翻译,以便trace文件中记录的信息能够被我们容易掌握和获取。
?
?
小知识:
检查当前会话的sql_trace状态或级别:
SQL>setserveroutputon
2????????declarei_eventnumber;
3????????begin
?3?sys.dbms_system.read_ev(10046,i_event);
?4?dbms_output.put_line(‘thesessionsql_tracelevelis:‘||i_event);
?5?end;
6????????/
thesessionsql_tracelevelis:12
?
PL/SQL过程已成功完成。
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 728x15, 创建于 08-4-23MSDN */google_ad_slot = "3624277373";google_ad_width = 728;google_ad_height = 15;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 160x600, 创建于 08-4-23MSDN */google_ad_slot = "4367022601";google_ad_width = 160;google_ad_height = 600;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
10046event漫步:
如果你对oracle性能调优很感兴趣或者比较专长,那么你对oracle的10046事件一定不会陌生。10046event是oracle用于系统性能分析时的一个最重要的事件。当激活这个事件后,将通知oraclekernel追踪会话的相关即时信息,并写入到相应trace文件中。这些有用的信息主要包括sql是如何进行解析,绑定变量的使用情况,会话中发生的等待事件等
10046event可分成不同的级别(level),分别追踪记录不同程度的有用信息。对于这些不同的级别,应当注意的是向下兼容的,即高一级的trace信息包含低于此级的所有信息。
?
10046event的追踪级别大致有:
level1:跟踪sql语句,包括解析、执行、提取、提交和回滚等。
level4:包括变量的详细信息
level8:包括等待事件
level12:包括绑定变量与等待事件
其中,level1相当于打开了sql_trace
?
10046event的启用和关闭:
前提条件:(先确保要event的会话环境符合条件)
1、?必须确保timed_statistics为TRUE,这个参数可以在会话级上进行修改。
2、?为了确保trace输出能够完整进行,还要调整此会话对trace文件大小的限制,一般将此限制取消,即将max_dump_file_size设置为UNLIMITED,或者设置为一个很大的阙值。
在满足了上述条件后,就可以启用10046event对会话进行后台跟踪了。
?
这里还有几种方式来启用10046event:
一种是在当前会话启用event,可以利用altersession+事件名称+level,
如:sql>altersessionsetevent‘10046tracenamecontextforever,level12’;
?
另外一种是启用别的会话进行event跟踪,可以利用oracle提供的dbms_system来完成。
如:sql>execdbms_system.set_ev(sid,serial#,10046,12,’’);
?
注意:
sql>execdbms_system.set_sql_trace_in_session(sid,serial#,true);
相当于打开了sql_trace。
?
event的关闭:
可以在通过下面的语句来关闭当前会话的event:
sql>altersessionsetevent‘10046tracenamecontextoff’;
?
也可以利用dbms_system包来关闭某个会话的event:
sql>executedbms_system.set_ev(sid,serial#,0,’’);
?
这里应当值得一提的是,TRACE将消耗相当的系统资源,因此我们在使用TRACE的时候应当慎重。对于正式的系统,应当只在必要的时候进行TRACE操作,并且应当及时关闭。
?
?
当利用事件trace完当前或某个session后,接下来我们的工作就是找到oracle生成的trace了。的初始化文件中user_dump_dest参数的设置将决定trace文件的生成位置。
?
从trace文件中查找和发现有用的信息,然后寻找必要的性能调整点并进行相应的调整:
大部分情况下,通过10046事件trace到文件里的信息包含了此会话中存在的性能问题,可以根据trace到的等待事件、SQL语句执行情况以及绑定变量的使用情况来进行分析和查找。
?
oracle提供了一个工具tkprof来对trace文件进行格式的翻译,以便trace文件中记录的信息能够被我们容易掌握和获取。
?
?
小知识:
检查当前会话的sql_trace状态或级别:
SQL>setserveroutputon
2????????declarei_eventnumber;
3????????begin
?3?sys.dbms_system.read_ev(10046,i_event);
?4?dbms_output.put_line(‘thesessionsql_tracelevelis:‘||i_event);
?5?end;
6????????/
thesessionsql_tracelevelis:12
?
PL/SQL过程已成功完成。
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 728x15, 创建于 08-4-23MSDN */google_ad_slot = "3624277373";google_ad_width = 728;google_ad_height = 15;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 160x600, 创建于 08-4-23MSDN */google_ad_slot = "4367022601";google_ad_width = 160;google_ad_height = 600;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
- 10046event漫步
- 10046 Event漫步
- 月下漫步
- 月球漫步
- 青春漫步
- 漫步云天
- 蜗牛漫步
- 漫步鼓浪屿
- 漫步闲谈
- 月球漫步
- 漫步小记
- 漫步校园
- PHP漫步
- 漫步森林
- 漫步空间
- 漫步森林
- 漫步校园
- 漫步校园
- 精妙SQL语句介绍
- 升级SQL SERVER 6.5到2000的注意事项
- 安装SQLSERVER2000的注意事项
- RF-IC Design
- internet与
- 10046event漫步
- 得到随机排序结果
- FREELISTSandFREELISTGROUPS.SCOPE&APPLICATION
- 空单元格的使用
- iAS10gopmnctlrestartproc无法启动的问题。
- SQLSERVER实用经验技巧集
- 存储过程备份SQL日志
- 关于日期的sql,做报表的时候可能有用!!!
- LMS算法MatLab实现