免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1293 | 回复: 0
打印 上一主题 下一主题

产生hanganalyze跟踪文件 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-22 08:54 |只看该作者 |倒序浏览
Metalink的对hanganalyze的描述是:
 
When a database has a severe performance response time, the cause of the problem can be a HANG.
Using HANGANALYZE trace files you can determine whether an Oracle process is blocking other processes,
before starting a performance analysis.

Caution: HANGANALYZE run at levels higher that 3 may generate a huge number of trace files for large systems.
Do not use levels higher than 3 without discussing their effects with Oracle Support.
 
 
使用eygle网站上提供的方式产生一个library cache pin:
 
建立一个空的procedure, pinning :
 
SYS@test SQL> create or replace procedure pinning
  2  is begin
  3  null;
  4  end;
  5  /
Procedure created.
 
建立一个procedure, calling ,调用pinning 

SYS@test SQL> create or replace procedure calling
  2  is
  3  begin
  4  pining;
  5  dbms_lock.sleep(600);
  6  end;
  7  /
Procedure created.
执行calling

SYS@test SQL> exec calling

=>暂停了
 
在另一个session 重建pinning

SYS@test SQL> create or replace procedure pining
  2  is begin
  3  null;
end;  4
  5  /  =
》这时候library cache pin就产生了
 
[oracle@dbalinux1 ~]$ dbi sessions
   SID    SERIAL# SPID     USERNAME        STATUS   SQL_HASH_VALUE EVENT
------ ---------- -------- --------------- -------- -------------- -------------
   143       4743 10717    SYS             ACTIVE       3918317640 PL/SQL lock t
   142       2407 10782    SYS             ACTIVE                0 library cache
 
使用oradebug来产生hanganalyze跟踪文件 ,因为测试机是单节点,所以只需这样执行
 
SYS@test SQL> oradebug hanganalyze 3;
Hang Analysis in /u01/app/oracle/admin/test/udump/test_ora_10875.trc
SYS@test SQL> oradebug hanganalyze 3;
Hang Analysis in /u01/app/oracle/admin/test/udump/test_ora_10875.trc
SYS@test SQL> exit
 
对于产生的trace文件就要具体分析了。
 
metalink 上的使用说明:
 
STEPS TO GENERATE A HANGANALYZE TRACE FILE:
========================================
Use the following set of commands to generate HANGANALYZE trace files.


1- Using SQL*Plus connect as "INTERNAL" (Oracle8i) or "/ AS SYSDBA" (Oracle9i)

2- Execute the following commands:
   SQL> oradebug hanganalyze 3
   ... Wait at least 1 minutes to give time to identify process state changes.
   SQL> oradebug hanganalyze 3

3- Open a separate SQL session and immediately generate a system state dump.

           $ sqlplus '/ as sysdba'
          oradebug setmypid
          oradebug unlimit
          oradebug dump systemstate 266
          wait 90 seconds
          oradebug dump systemstate 266
          wait 90 seconds
          oradebug dump systemstate 266
          quit


Note: Starting with Oracle 9.2 HANGANALYZE can generate HANGANALYZE cluster wide.
Using this feature you can generate session dependencies to all the sessions
connected to all the instances of the RAC cluster. Use the following set of commands
to generate a RAC cluster wide HANGANALYZE:

1- Using SQL*Plus connect as "/ AS SYSDBA"
2- Execute the following commands:
   SQL> oradebug setmypid
   SQL> oradebug setinst all
   SQL> oradebug -g def hanganalyze 3
   ... Wait at least 1 minutes to give time to identify process state changes.
   SQL> oradebug -g def hanganalyze 3

 
除此之外oradebug还能做很多事情,还得好好学习一下。
 
参考:Steps to generate HANGANALYZE trace files [ID 175006.1]
 

 
 
 
 
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP