工作中遇到的oracle故障分析和处理一例

案例类别: VAS网络 
系统类型: CMODE
系统版本: 硬件:SUN  软件:所有版本
案例标题: CMODE放号中的数据库出现LOCK的处理方法 
故障现象: 启动sam_cmode进程不能正常处理工单。
故障描述: 启动以sam_cmode –d方式启动发现sam_cmode始终在处理一个用户。
connected
4c 4f 47 49 4e 3a 55 53 45 52 4e 41 4d 45 3d 22
75 74 62 6a 22 2c 50 41 53 53 57 4f 52 44 3d 22
75 74 62 6a 31 32 33 22 0d 0a
send: LOGIN:USERNAME="utbj",PASSWORD="utbj123"

recv: LOGIN:RESULT=0

connect cmode successful!
44 45 4c 20 30 38 35 31 38 37 34 33 32 31 30 3a
0d 0a
send DEL 08518743210:
a connection break or timeout in recv
commu err when delete event
 
故障分析: 在CMODE的数据库中手动删除该用户记录,发现oracle无任何反馈信息。
(正常情况下会出现oracle的完整性约束报错。ORA-02292: integrity constraint (PDXDBA.FK_TSIGNUP_USERID) violated - child record found)
初步怀疑tcontract表中该用户记录被锁定。

通过查询oracle的视图,发现目前有用户正在update该用户记录,且发现有很多update操作没有commit。
SQL> select a.SERIAL#,a.SID,c.SQL_TEXT,a.program from v$session a,v$locked_object b,v$sqltext c where a.sid=b.SESSION_ID and c.SQL_TEXT like 'update tcontract set %' and a.program like 'sqlplus%' order by a.sid;

update tcontract set lstatus='E' where tel='08518743210'
sqlplus@gz_signup (TNS V1-V3)

     14895        234
 
故障处理: 通过oracle命令将这些session杀死。重启sam_cmode和signup模块。
alter system kill session '234,14895';
 
日常维护: 1.维护人员尽量不要手工修改CMODE数据库中的数据。
2.修改完毕确认正确后及时执行commit操作。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1 由于ARCHIVE挂起导致数据库挂死 2 NIT文件SGA区设置太大,导致内存不够用,数据库和系统都挂死 3 由于临时表空间无法扩展导致数据库被挂起 4由于未打补丁导致RMAN备份时将数据库挂起 5由于BLOB类型的表记录数太多操作又太频繁导致数据库效率急差 6由于未对特大表(达到或超过100万条记录)定期做表分析导致数据库操作特别慢 7由于空间不够导致插入数据时扩展索引失败 8由于REDOLOG破坏导致数据库异常 9由于控制文件被破坏导致数据库无法正常启动 10由于数据文件丢失或破坏导致数据库无法正常启动 11由于空间参数设置不合理导致扩展表空间、索引等失败 12由于时间格式的环境变量设置问题导致话单无法入库 13由于大事务未使用大回滚段导致事务挂起 14由于数据库连接数太多导致服务器进程数多或内存耗尽 15由于使用了MTS方式,导致数据库操作特别慢(包括备份) 16由于存在一个大事务操作,导致数据库性能特别差或产生频繁日志切换 17由于没有COMMIT,导致数据库表被锁住 18索引创建不合理,导致数据库查询特别慢 19 由于BUFFER参数设置不合理导致EXP失败 20由于EXP不向上兼容,语言不兼容,导致不同版本、不同字符集的数据库无法导入 21 由于创建表空间时误将其创建在以‘本地管理’,导致在表空间上的所有对象无法修改其存储参数 22 错误地在系统表空间上建无关的数据文件 23 ORACLE客户端在P4上安装不成功 24由于LISTENER.ORA或TNSNAMES.ORA配置问题导致网络问题 25由于环境变量设置问题导致VERSOIN版本启动问题 26用户数据、表破坏下的数据恢复 27 由于OS层问题导致数据库ORA-600错误 .....

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值