oracle故障处理步骤,一次Oracle故障处理过程

中午接到报警,tomcat连接Oracle并发数超过阀值,首先怀疑是否刚更新了程序,但询问一番后答案都是否。然后怀疑是有人进行大的操作。

登录到数据库机器,用top查看,是否有消耗资源的进程。发现所有的进程资源消耗比较平均,应该没有人在进程大查询或者大的操作。

使用ASH,查看数据库近15分钟发生了什么。

SYS@sg>@?/rdbms/admin/ashrpt

Defaults TO -15 mins

Enter VALUE FOR begin_time: -15

Report BEGIN TIME specified: -15

打开报告,发现可疑的sql。

SQL ID    Planhash % Activity Event                             % Event

------------- ----------- ---------- ------------------------------ ----------

2ghd19kmj1m1t  2931439336      97.04 enq: TX - ROW LOCK contention       96.89

UPDATE tb_name WHERE ......

-------------------------------------------------------------

这条语句,产生的enq: TX - row lock contention事件,占了整个的96.89%,确认问题就好解决了。

SELECT a.sid, b.SERIAL#,a.state, a.wait_time

FROM v$session_wait a,v$session b

WHERE a.wait_class='Application' AND a.event='enq: TX - row lock contention'

AND a.sid=b.sid ORDER BY a.wait_class, a.event, a.sid;

SID    SERIAL# STATE     WAIT_TIME

---------- ---------- ------------------- ----------

1817 42155 WAITING      0

1819 38267 WAITING      0

1824 43045 WAITING      0

1827 29392 WAITING      0

1831 56038 WAITING      0

1833 16463 WAITING      0

1836 13558 WAITING      0

7 rows selected.

SYS@sg>alter system kill session '1817,42155';

System altered.

杀掉相关进程,OK问题解决。在找开发人员,修改相关的应用。

这里只是提供一个思路,发生问题的时候,一定需要冷静思考问题可能出现的地方,先找出问题的所在,再根据问题去解决。0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值