ORACLE數據庫慢排除
2016-04-26 13:35
381 查看
1、查詢當前被鎖的進程、用戶、對象。
select sess.sid,
sess.serial#,
lo.oracle_username,
lo.os_user_name,
ao.object_name,
lo.locked_mode
from v$locked_object lo, dba_objects ao, v$session sess
where ao.object_id = lo.object_id and lo.session_id = sess.sid;
2、批量KILL進程
declare
v_minutes NUMBER:=1000;
v_Str VARCHAR2(100);
CURSOR C_users(v_minutes number) IS
SELECT s.username,
s.status, s.machine, 'alter system kill session '
||''''||s.sid||','||s.serial# ||'''' operates
FROM v$session s, v$process p
WHERE TYPE = 'USER'
AND p.addr = s.paddr
AND status != 'KILLED'
and exists
(select 1
from dba_ddl_locks a,
v$session b
where a.session_id=b.SID
and b.USERNAME NOT IN ('IFSAPP','AUTOS','THK') --
and b.sid = s.sid)
ORDER BY last_call_et desc;
BEGIN
FOR T_users IN C_users(v_minutes) LOOP
v_Str := T_USERS.OPERATES;
BEGIN
EXECUTE IMMEDIATE v_str;
EXCEPTION
WHEN OTHERS THEN
NULL;
END;
END LOOP;
END;
3、查詢用戶執行時間
select --l.*,o.owner object_owner, o.object_Name,mac.status,mac.osuser,mac.machine
trunc(l.ctime/60,0) mm,(l.ctime/60-trunc(l.ctime/60,0))*60 ss,
l.sid,mac.SERIAL# serial,l.type,mac.osuser,mac.machine,mac.USERNAME user_, o.object_Name,mac.status,
mac.logon_time,'kill -9 '||(select spid from v$process p, v$session s where p.addr=s.paddr and s.sid =mac.sid) spid
,mac.program --,mac.*,o.*
from (select l.* from v$lock l where l.type = 'TM') l,
sys.all_objects o, sys.v_$session mac
where l.id1 = o.object_id
and l.sid = mac.sid;
4、查詢耗時較長的進程
SELECT c.last_call_et, b.value ,c.PROGRAM,c.MACHINE , c.status, c.*,
c.SERIAL#,c.SCHEMANAME,c.TERMINAL
FROM v$statname a,v$sesstat b, v$session c
WHERE a.STATISTIC# =b.STATISTIC#
AND b.sid =c.sid
AND a.name ='CPU used by this session'
AND Value > 100000
ORDER BY Value DESC;
SELECT c.last_call_et, b.value ,c.PROGRAM,c.MACHINE , c.status, c.*,
c.SERIAL#,c.SCHEMANAME,c.TERMINAL
FROM v$statname a,v$sesstat b, v$session c
WHERE a.STATISTIC# =b.STATISTIC#
AND b.sid =c.sid
AND a.name ='consistent gets'
AND Value > 100000000
ORDER BY Value DESC
select sess.sid,
sess.serial#,
lo.oracle_username,
lo.os_user_name,
ao.object_name,
lo.locked_mode
from v$locked_object lo, dba_objects ao, v$session sess
where ao.object_id = lo.object_id and lo.session_id = sess.sid;
2、批量KILL進程
declare
v_minutes NUMBER:=1000;
v_Str VARCHAR2(100);
CURSOR C_users(v_minutes number) IS
SELECT s.username,
s.status, s.machine, 'alter system kill session '
||''''||s.sid||','||s.serial# ||'''' operates
FROM v$session s, v$process p
WHERE TYPE = 'USER'
AND p.addr = s.paddr
AND status != 'KILLED'
and exists
(select 1
from dba_ddl_locks a,
v$session b
where a.session_id=b.SID
and b.USERNAME NOT IN ('IFSAPP','AUTOS','THK') --
and b.sid = s.sid)
ORDER BY last_call_et desc;
BEGIN
FOR T_users IN C_users(v_minutes) LOOP
v_Str := T_USERS.OPERATES;
BEGIN
EXECUTE IMMEDIATE v_str;
EXCEPTION
WHEN OTHERS THEN
NULL;
END;
END LOOP;
END;
3、查詢用戶執行時間
select --l.*,o.owner object_owner, o.object_Name,mac.status,mac.osuser,mac.machine
trunc(l.ctime/60,0) mm,(l.ctime/60-trunc(l.ctime/60,0))*60 ss,
l.sid,mac.SERIAL# serial,l.type,mac.osuser,mac.machine,mac.USERNAME user_, o.object_Name,mac.status,
mac.logon_time,'kill -9 '||(select spid from v$process p, v$session s where p.addr=s.paddr and s.sid =mac.sid) spid
,mac.program --,mac.*,o.*
from (select l.* from v$lock l where l.type = 'TM') l,
sys.all_objects o, sys.v_$session mac
where l.id1 = o.object_id
and l.sid = mac.sid;
4、查詢耗時較長的進程
SELECT c.last_call_et, b.value ,c.PROGRAM,c.MACHINE , c.status, c.*,
c.SERIAL#,c.SCHEMANAME,c.TERMINAL
FROM v$statname a,v$sesstat b, v$session c
WHERE a.STATISTIC# =b.STATISTIC#
AND b.sid =c.sid
AND a.name ='CPU used by this session'
AND Value > 100000
ORDER BY Value DESC;
SELECT c.last_call_et, b.value ,c.PROGRAM,c.MACHINE , c.status, c.*,
c.SERIAL#,c.SCHEMANAME,c.TERMINAL
FROM v$statname a,v$sesstat b, v$session c
WHERE a.STATISTIC# =b.STATISTIC#
AND b.sid =c.sid
AND a.name ='consistent gets'
AND Value > 100000000
ORDER BY Value DESC
相关文章推荐
- iptables的nf_conntrack相关参数引起两个问
- Oracle 表分区与索引分区
- _use_adaptive_log_file_sync参数分析
- Oracle 控制文件和日志文件
- 《oracle每天一练》触发器不能调用或间接调用COMMIT,ROLLBACK等DCL语句
- oracle 分组编号 ROW_NUMBER() OVER(PARTITION BY COLUMN ORDER BY COLUMN ) 的用法
- Oracle default 函数记录(sys_guid......)
- Oracle EBS中订单登记后,发放销售订单以便挑库时,找不到相应的销售订单
- oracle 删除步骤
- Oracle中的分组group by rollup/cube
- oracle启动过程
- Oracle中tnsping命令解析
- Oracle正则表达式使用介绍
- Oracle编译存储过程卡死的问题
- oraclelinux系统udev配置
- Oracle数据库技术教程
- Ruby通过OCI8操作Oracle存储BLOB
- 【ORACLE】 表空间信息
- Oracle 表空间
- PHP链接ORACLE遇到的几个坑