zoukankan      html  css  js  c++  java
  • cpu 过高检查

    1:首先使用TOP命令传到占用CPU高的SPID号
    PID USERNAME THR PRI NICE SIZE RES STATE TIME CPU COMMAND
    3575 oracle 1 12 0 0K 0K run 748.6H 24.98% oracle
    3571 oracle 1 22 0 0K 0K sleep 706.2H 22.84% oracle
    2:使用DBA账户登录数据库,使用以下SQL语句查询:
    SELECT * FROM V$PROCESS WHERE spid=3575;查询到SQL相关信息
    3:根据以上查询到的信息使用以下SQL查询:
    SELECT sid, program FROM V$SESSION S WHERE EXISTS(SELECT 1 FROM V$PROCESS WHERE spid=3575 AND ADDR = S.PADDR);
    可以查询到具体那个客户端查询一直在不断占用ORACLE资源!
    最后对这个查询进行处理!
    4.根据SID查得SQLITPUB复制代码代码如下:select sql_textITPUB
    from v$sqltext
    where a.hashvalue=(select sql_hash_value
    from v$session b
    where b.SID='&sid')
    0order by piece ASC;
    根据lockwait字段可以查询当前正在等待的锁的相关信息:复制代码代码如下:select * from v$lock where kaddr in (select lockwait from v$session where sid= $sid);
    (sql_address,sql_hash_value),(prev_sql_addr,prev_hash_value) 根据这两组字段, 可以查询到当前session正在执行的或最近一次执行的sql语句的详细信息:
    select * from v$sqltext where address = &sql_address and hash_value = &sql_hash_value;
    根据PID查SQL相关信息:复制代码代码如下:select id,serial# ,username,osuser,machine,program,process,to_char(logon_time,'yyyy/mm/dd hh24:mi:ss') logon from v$session where paddr in ( select addr from v$process where spid in('&pid'));
    根据PID查SQL语句复制代码代码如下:SELECT a.username,a.machine,a.program,a.sid,a.serial#,a.status,c.piece,c.sql_text FROM v$session a,v$process b,v$sqltext c WHERE b.spid='&spid' AND b.addr=a.paddr AND a.sql_address=c.address(+) ORDER BY c.piece;
    得到进程的sid号:复制代码代码如下:select id,serial# ,username,osuser,machine,program,process,to_char(logon_time,'yyyy/mm/dd hh24:mi:ss') logon from v$session where paddr in ( select addr from v$process where spid in('&pid'));
    得到session的sqltext语句:复制代码代码如下:select sql_text from v$sqltext_with_newlines where hash_value in (select SQL_HASH_VALUE from v$session where paddr in (select addr from v$process where spid= '&pid')) order by piece;
  • 相关阅读:
    2.4 Git 基础
    MySQL的连接命令
    linux中的ls、cd、pwd命令
    Vim 快速入门之基本命令
    linux 中查看进程、杀死进程、进入进程的命令
    linux下文件夹的创建、复制、剪切、重命名、清空和删除的命令
    Linux下tar压缩和解压缩命令详解
    用Windows远程桌面连接树莓派的方法
    MariaDB数据库安装完需要初始化操作
    linux设置服务为自动启动和关闭并禁用的命令
  • 原文地址:https://www.cnblogs.com/yaoyangding/p/12808460.html
Copyright © 2011-2022 走看看