Oracle杀会话回滚时间长处理办法

Oracle杀会话回滚时间长处理办法

获取被KILL会话的SID:

sql 复制代码
set line 200 pages 1000
col event for a30
col program for a35
col username for a10
col exec_time for 9999999999
col sql_id for a15
col machine for a30
col ssid for a13
col state for a20
col status for a10
select inst_id||':'||sid||','||serial# ssid,username,sql_id,sql_exec_id,event,
substr(program,1,25) program,machine,state,last_call_et exec_time,status 
from gv$session 
where wait_class<>'Idle' and username is not null 
order by last_call_et;

...
1:633,52377   APPUSER   13bqm6vvsn5s6	 db file sequential read	 sqlplus@etlhost (TNS V1-V3)	etlhost	   WAITING	243509  KILLED

注意最后一列状态为KILLED

获取被KILL会话对应的操作系统进程号PID:

sql 复制代码
select spid from v$process 
where addr in (select paddr 
from v$session 
where username='APPUSER' and sid=633);

SPID
------------------------
273322

--或者
select spid from v$process 
where addr in (select creator_addr 
from v$session 
where username='APPUSER' and status='KILLED');

或者:

sql 复制代码
SET LINESIZE 100
COLUMN spid FORMAT A10
COLUMN username FORMAT A10
COLUMN program FORMAT A45
 
SELECT s.inst_id,
       s.sid,
       s.serial#,
       p.spid,
       s.username,
       s.program
FROM   gv$session s
       JOIN gv$process p ON p.addr = s.paddr AND p.inst_id = s.inst_id
WHERE  s.type != 'BACKGROUND' 
and s.username='APPUSER';

   INST_ID	  SID	 SERIAL# SPID	    USERNAME   PROGRAM
---------- ---------- ---------- ---------- ---------- ---------------------------------------------
	 1	  633	   52377 273322     APPUSER    sqlplus@etlhost (TNS V1-V3)
	 1	  722	    1331 104848     APPUSER    sqlplus@etlhost (TNS V1-V3)
	 1	  777	   64051 104254     APPUSER    sqlplus@etlhost (TNS V1-V3)
	 1	  938	   51475 104793     APPUSER    sqlplus@etlhost (TNS V1-V3)
	 1	 1101	   55005 161435     APPUSER    plsqldev.exe
	 1	 1172	   21141 101804     APPUSER    sqlplus@etlhost (TNS V1-V3)
	 1	 2036	   42029 161411     APPUSER    plsqldev.exe

7 rows selected.

操作系统层面杀掉对应连接:

bash 复制代码
[oracle@dbhost ~]$ ps -ef | grep oracle | grep LOCAL | grep 273322
oracle   273322      1 28 Oct15 ?        19:25:50 oracleorcldb (LOCAL=NO)

[oracle@dbhost ~]$ kill -9 273322

References

1\] https://blog.51cto.com/u_13631369/6251425

相关推荐
格调UI成品1 小时前
预警系统安全体系构建:数据加密、权限分级与误报过滤方案
大数据·运维·网络·数据库·安全·预警
心平愈三千疾6 小时前
通俗理解JVM细节-面试篇
java·jvm·数据库·面试
我科绝伦(Huanhuan Zhou)9 天前
Oracle|Oracle SQL*Plus 配置上下翻页功能
数据库·sql·oracle
Cachel wood9 天前
Spark教程6:Spark 底层执行原理详解
大数据·数据库·分布式·计算机网络·spark
java—大象9 天前
基于java SSM的房屋租赁系统设计和实现
java·开发语言·数据库·spring boot·layui·mybatis
Mutig_s9 天前
Spring Boot动态数据源切换:优雅实现多数据源管理
java·数据库·spring boot·后端·mybatis
Python小老六9 天前
单片机测ntc热敏电阻的几种方法(软件)
数据库·单片机·嵌入式硬件
矿渣渣9 天前
SQLite3 在嵌入式系统中的应用指南
数据库·sqlite·嵌入式实时数据库
@昵称不存在9 天前
Python csv 模块
开发语言·数据库·python
程序猿小D9 天前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+Vue实现的校园二手交易平台管理系统,推荐!
java·数据库·mysql·spring·vue·毕业设计·校园二手交易平台