大家好,我是考100分的小小码 ,祝大家学习进步,加薪顺利呀。今天说一说Oracle实例占用超高CPU排查[通俗易懂],希望您对编程的造诣更进一步.
CPU主要功能:处理指令、执行操作、要求进行动作、控制时间、处理数据。
结合数据库实例CPU占用高,可能的原因是数据库在执行大量的操作(全表查询、大量排序等)。
由于公司没有DBA,遇到数据库问题只能自己排查。
一、是否存在死锁
- 查看死锁ID
- 查看表名称
- 手工关闭死锁
二、借助PLSQL查询定时job和session
三、查询数据库中的等待事件
SELECT P.PID,
S.SID,
S.SERIAL#,
S.USERNAME,
Q.SQL_ID,
Q.SQL_TEXT,
Q.SQL_FULLTEXT,
W.EVENT,
W.WAIT_TIME,
W.STATE,
CASE
WHEN W.STATE = “WAITING” THEN
W.SECONDS_IN_WAIT
WHEN W.STATE = “WAITING KNOWN TIME” THEN
W.WAIT_TIME
END AS SEC_IN_WAIT
FROM V$SESSION S, V$SESSION_WAIT W, V$SQLAREA Q, V$PROCESS P
WHERE S.SID = W.SID
AND S.SQL_ID = Q.SQL_ID
AND P.ADDR = S.PADDR
AND W.EVENT NOT LIKE “SQL*Net%”
AND S.USERNAME IS NOT NULL
AND W.WAIT_TIME >= 0
ORDER BY W.WAIT_TIME DESC;
发现存在等待事件,分析待执行的SQL发现存在多表(百万数据)全量关联查询。
于是对数据以及SQL进行了相应优化,CPU占用较高问题得到根本解决。
四、过程总结
造成CPU暴增的原因有很多,思路也有很多,后续如果遇到可以参考上述思路,精准定位到问题并进行优化。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10257.html