如何立刻知道哪条SQL语句使得CPU,内存利用率过高?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何立刻知道哪条SQL语句使得CPU,内存利用率过高?相关的知识,希望对你有一定的参考价值。
参考技术A 查看进程消耗内存情况psaux
|
head
-1
;
ps
aux
|
sort
-rn
+3
|
head根据进程号查看所执行的语句select
/*+
ordered
*/
sql_text
from
v$sqltext
sql
where
(sql.hash_value,
sql.address)
in
(
select
decode(sql_hash_value,
0,
prev_hash_value,
sql_hash_value),
decode(sql_hash_value,
0,
prev_sql_addr,
sql_address)
from
v$session
s
where
s.paddr
=
(select
addr
from
v$process
p
where
p.spid
=
to_number('&pid'))
)
order
by
piece
asc; 参考技术B 监控软件,比如:veritas
i3,该软件能够显示sql
使用cpu使用率的情况。
Oracle查询语句导致CPU使用率过高问题处理
解决此问题的关键在于如何找到造成CPU使用率过高的SQL语句。步骤如下:
1、使用Process Explorer工具查看到Oracle进程,双击Oracle进程,在弹出的属性窗口的Threads选项卡中查看占用CPU较高的线程号(TID)。
2、在PL/SQL工具中执行以下SQL语句:
--根据sql_id获取对应的Sql语句(sql_text,sql_fulltext)
select *
from v$sqlarea
where sql_id in
(
--根据addr获取sql_id
select sql_id
from v$session
where paddr in
--根据线号获取process的addr
(select addr from v$process where spid in (‘&spid:线程号‘))
);
3、在上述SQL查询语句的结果中 “sql_text"、"sql_fulltext"两列就是要找的SQL语句。
4、根据不同的SQL语句进行调优即可。
以上是关于如何立刻知道哪条SQL语句使得CPU,内存利用率过高?的主要内容,如果未能解决你的问题,请参考以下文章