UPDATE To USER$.SPARE6的sql导致数据库hang住

针对应用反应数据库在特定时间段运行缓慢的问题,通过分析历史活动会话发现存在library cache lock及logfile switch incomplete等问题,并最终确定为未打补丁引起,通过查找对应bug ID找到解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

应用反应数据库在9点05分左右运行缓慢

下面我们通过ash对当时的数据库会话做出分析

--查看历史active会话的event数

select INSTANCE_NUMBER,EVENT,BLOCKING_SESSION,count(*) from dba_hist_active_sess_history 

where sample_time>= to_date('2018-06-04 09:00:00','yyyy-mm-dd hh24:mi:ss') and  sample_time<= to_date('2018-06-04 09:30:00','yyyy-mm-dd hh24:mi:ss')

group by INSTANCE_NUMBER,EVENT,BLOCKING_SESSION

order by 4,2,3,1

;


library cache lock严重,而且还有log file switch incomplete的问题

 

--查看1534session

select INSTANCE_NUMBER,session_id,EVENT,BLOCKING_SESSION,sql_id  from dba_hist_active_sess_history 

where sample_time>= to_date('2018-06-04 09:00:00','yyyy-mm-dd hh24:mi:ss') and  sample_time<= to_date('2018-06-04 09:30:00','yyyy-mm-dd hh24:mi:ss')

and session_id=1534

;

library cache lock的堵塞源头还是log file switch

查看当时的sql


一个update user$的语句,这是一个数据库内部的sql,按理说应该不会造成问题


--alert日志



--select INST_ID,group#,thread#,bytes/1024/1024 mb,members,status from  gv$log order by 3,2

redo log配置还是比较大的,3组1gb,事务量不大就不会造成check point not complete的问题。

因为当前环境是12.1.0.2,没有打补丁(因为之前打补丁时遇到bug再见),在mos上搜索update那条sql,很容易就搜到了。

bug 25839004,只要打上最新的补丁就行了。

因为psu中的readme只有opatchauto方式打补丁,但是opatchauto在这个库上打不了补丁(这也是bug),导致遇到更多的bug,只有自己整理手动打补丁方案。12c的坑还是多呀。


参考文档:

UPDATE To USER$.SPARE6 Performs Poorly (2-Second Execution Time) and Consumes CPU (文档ID 2280676.1)

Bug 25839004 : SLOW LOGIN UPDATE USER$ QUERY WHEN TDE AND DBFIPS_140 ENABLED


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

liuzhilongDBA

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值