oracle oradebug使用详解

来源:这里教程网 时间:2026-03-03 16:39:06 作者:

oradebug的前身是在ORACLE 7时的ORADBX,它可以启动用停止跟踪任何会话,dump SGA和其它内存结构,唤醒ORACLE进程,如SMON、PMON进程,也可以通过进程号使进程挂起和恢复等,还有很多功能,实际上这些功能都不常用,最好用的是直接通过命令输出生成trace文件的名称(带路径的哦),省去不少麻烦,系统HANG住用它做分析也比较好用,和大家分享一下它最常用的方法!1> oradebug有哪些可用命令?  以sysdba身份登陆数据库,通过oradebug help可以看到oradebug常用命令  sqlplus / as sysdba  oradebug help2> 跟踪当前会话信息  oradebug setmypid  --跟踪当前会话  oradebug setospid  --跟踪系统进程  oradebug setorapid  --跟踪ORACLE进程  oradebug unlimit   --取消trace文件大小限制       oradebug tracefile_name  --查看trace文件名及位置3> 用oradebug做session级10046或10053  oradebug setmypid   oradebug unlimit  oradebug session_event 10046 trace name context forever ,level 4 --启用会话级10046  oradebug event 10046 trace name context off   --关闭10046事件  oradebug tracefile_name  --查看tracefile文件位置及文件名4> 用oradebug做oracle process级10046  oradebug setorapid  oradebug unlimit  oradebug event 10046 trace name context forever ,level 4  oradebug event 10046 trace name context off   oradebug tracefile_name5> oradebug系统hang住原因分析   如果系统HANG住,只要sys用户可以登陆,那么用oradebug做原因分析是非常有用的  oradebug setmypid  oradebug unlimit  oradebug setinst all   --RAC环境  oradebug hanganalyze 3  -- 级别一般指定为3足够了  oradebug -g def dump systemstate 10  --RAC环境  oradebug tracefile_name6> 获取某进程的状态信息  oradebug setospid 22180   oradebug dump processstate 10  oradebug tracefile_name7> 获取进程错误信息状态  oradebug setospid 22180  oradebug dump errorstack 38> 追踪造成错误信息的原因,如ORA-04031   oradebug event 4031 trace name errorstack level 3

相关推荐