CPU主要功能:处理指令、执行操做、要求进行动做、控制时间、处理数据。sql
结合数据库实例CPU占用高,可能的缘由是数据库在执行大量的操做(全表查询、大量排序等)。数据库
因为公司没有DBA,遇到数据库问题只能本身排查。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暴增的缘由有不少,思路也有不少,后续若是遇到能够参考上述思路,精准定位到问题并进行优化。io