通信人家园

 找回密码
 注册

只需一步,快速开始

短信验证,便捷登录

搜索

军衔等级:

  新兵

注册:2024-7-11
跳转到指定楼层
1#
发表于 2026-3-23 17:27:56 |只看该作者 |倒序浏览
1、 根据占用CPU高的进程号来查询这个进程执行的SQL语句:
CPU过高的进程号:
#首先找到CPU过高的进程号
# top -bn1 是静态找到占用最高的进程

[root@localhost ~]# top -bn1 | awk '{print $1}' | grep -A2 PID

命令详解:  
  top:top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况
  -bn1: 显示所有的进程信息  (top -bn 1    显示所有进程信息,top -n 1 只显示一屏信息,供管道调用  )
  awk '{print $1}':    awk是用来提取列的主要工具;
    {print $1}就是将某一行(一条记录)中以空格为分割符的第一个字段打印出来
 grep -A2 PID :  (查看前二行的进程号)             -A: 显示匹配行及前面多少行, 如: -A3, 则表示显示匹配行及前3行





SQL语句:

SELECT sql_text
FROM V$sqltext a
WHERE (a.hash_value, a.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 b
WHERE b.paddr = (SELECT addr FROM v$process c WHERE c.spid = '&pid'))
ORDER BY piece ASC;

#######
ex:
SELECT sql_text
FROM v$sqltext a
WHERE (a.hash_value, a.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 b
WHERE b.paddr = (SELECT addr FROM v$process c WHERE c.spid = '3515'))
ORDER BY piece ASC;

举报本楼

本帖有 1 个回帖,您需要登录后才能浏览 登录 | 注册
您需要登录后才可以回帖 登录 | 注册 |

版规|手机版|C114 ( 沪ICP备12002291号-1 )|联系我们 |网站地图  

GMT+8, 2026-3-25 04:28 , Processed in 0.157796 second(s), 17 queries , Gzip On.

Copyright © 1999-2025 C114 All Rights Reserved

Discuz Licensed

回顶部