Errorstack 和 oradebug 命令类似,都是帮助我们诊断错误信息。有关oradebug 参考我的Blog:
Oracle oradebug 命令 使用说明
http://blog.csdn.net/tianlesoftware/archive/2011/06/04/6525628.aspx
Errorstack事件:dump 错误栈信息,通常Oracle 发生错误时前台进程将得到一条错误信息,但某些情况下得不到错误信息,可以采用这种方式得到Oracle错误。
使用errorstack 步骤:
1. 启用:
SQL> alter system set events='1438 trace name errorstack forever,level 10';
-- 表示当出现ORA-1438 错误时,dump 错误栈和进程栈。
--在这里,我们关注哪些错误,就写上对应的代码就ok了。
2. 执行相关的SQL ,获取跟踪文件
3. 关闭:
SQL> alter system set events='1438 trace name errorstack off';
或者使用oradebug :
-- 启用
SQL> oradebug event 1000 trace name errorstack level 10;
Statement processed.
-- 关闭
SQL> oradebug event 1000 trace name errorstack off;
Statement processed.
示例:
SQL> alter system set events='600 trace name errorstack forever,level 10';
System altered.
SQL> select * from dba_data_files;
ERROR:
ORA-00600: internal error code, arguments: [ktfbhget-4], [6], [5], [], [], [],
[], []
no rows selected
SQL> alter system set events='600 trace name errorstack off';
System altered.
--- 获取trace name
SQL> oradebug setmypid
Statement processed.
SQL> oradebug tracefile_name
/u01/app/oracle/admin/dave1/udump/dave1_ora_29181.trc
SQL>
这里使用的是oradebug,这个比较方便,之前还有一个获取tracename的sql脚本,参考我的Blog:
Oracle SQL Trace 和 10046 事件
http://blog.csdn.net/tianlesoftware/archive/2010/09/02/5857023.aspx
然后根据trace,分析相关的原因。
ITPUB 论坛上的一个完整示例:
一次ora-01438 错误的处理
http://www.itpub.net/thread-956435-1-1.html
-------------------------------------------------------------------------------------------------------
Blog: http://blog.csdn.net/tianlesoftware
Email: dvd.dba@gmail.com
DBA1 群:62697716(满); DBA2 群:62697977(满) DBA3 群:62697850(满)
DBA 超级群:63306533(满); DBA4 群: 83829929 DBA5群: 142216823
DBA6 群:158654907 聊天 群:40132017 聊天2群:69087192
--加群需要在备注说明Oracle表空间和数据文件的关系,否则拒绝申请
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com