免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5428 | 回复: 4

[数据库] 如何立刻知道哪条SQL语句使得CPU,内存利用率过高? [复制链接]

论坛徽章:
0
发表于 2013-12-11 10:15 |显示全部楼层
同题目,多谢了。

论坛徽章:
14
处女座
日期:2013-11-26 09:21:15操作系统版块每日发帖之星
日期:2016-03-25 06:20:00操作系统版块每日发帖之星
日期:2016-03-22 06:20:00操作系统版块每日发帖之星
日期:2016-03-21 06:20:00数据库技术版块每日发帖之星
日期:2015-11-13 06:20:00操作系统版块每日发帖之星
日期:2015-11-01 06:20:002015亚冠之卡尔希纳萨夫
日期:2015-09-29 13:31:42IT运维版块每日发帖之星
日期:2015-08-13 06:20:00IT运维版块每日发帖之星
日期:2015-08-10 06:20:00数据库技术版块每日发帖之星
日期:2015-08-06 06:20:00双鱼座
日期:2014-07-17 15:08:51卯兔
日期:2014-04-08 09:54:34
发表于 2013-12-12 16:06 |显示全部楼层
本帖最后由 royzs 于 2013-12-12 16:08 编辑

查看执行计划,查看v$session,v$process,v$sesstat

论坛徽章:
1
辰龙
日期:2013-11-20 14:55:50
发表于 2013-12-12 16:50 |显示全部楼层
输出个awr 吧

论坛徽章:
0
发表于 2013-12-14 11:39 |显示全部楼层

查看进程消耗内存情况
ps aux | 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;

论坛徽章:
7
天蝎座
日期:2013-08-16 23:19:32丑牛
日期:2014-01-08 09:20:14寅虎
日期:2014-01-11 11:03:44午马
日期:2014-04-28 11:02:40天秤座
日期:2014-05-16 23:24:24摩羯座
日期:2014-07-20 10:46:04卯兔
日期:2014-08-08 15:21:41
发表于 2013-12-15 18:05 |显示全部楼层
监控软件,比如:veritas i3,该软件能够显示sql 使用cpu使用率的情况。

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP