Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1934561
  • 博文数量: 389
  • 博客积分: 7877
  • 博客等级: 少将
  • 技术积分: 4531
  • 用 户 组: 普通用户
  • 注册时间: 2007-12-10 14:02
文章分类

全部博文(389)

文章存档

2024年(1)

2022年(1)

2021年(1)

2020年(1)

2019年(1)

2018年(3)

2017年(6)

2016年(4)

2015年(8)

2014年(15)

2013年(31)

2012年(19)

2011年(47)

2010年(33)

2009年(105)

2008年(109)

2007年(4)

分类: Oracle

2009-03-20 14:04:24

今天在Oracle上面跑一个存储过程,就是那个不断造数据的那个,因为循环的设置大了点,估计要等很久才能跑完,于是就想直接干掉这个进程,在网上找到如下杀掉Oracle死锁的东西:

Oracle杀死死锁进程

先查看哪些表被锁住了:

select b.owner,b.object_name,a.session_id,a.locked_mode
from v$locked_object a,dba_objects b
where b.object_id = a.object_id;

OWNER OBJECT_NAME SESSION_ID LOCKED_MODE
------------------------------ -----------------
WSSB SBDA_PSHPFTDT 22 3
WSSB_RTREPOS WB_RT_SERVICE_QUEUE_TAB 24 2
WSSB_RTREPOS WB_RT_NOTIFY_QUEUE_TAB 29 2
WSSB_RTREPOS WB_RT_NOTIFY_QUEUE_TAB 39 2
WSSB SBDA_PSDBDT 47 3
WSSB_RTREPOS WB_RT_AUDIT_DETAIL 47 3

select b.username,b.sid,b.serial#,logon_time
from v$locked_object a,v$session b
where a.session_id = b.sid order by b.logon_time;

USERNAME SID SERIAL# LOGON_TIME
------------------------------ ---------- -------
WSSB_RTACCESS 39 1178 2006-5-22 1
WSSB_RTACCESS 29 5497 2006-5-22 1

杀进程中的会话:

alter system kill session 'sid,serial#';
e.g
alter system kill session '29,5497';

如果有ora-00031错误,则在后面加immediate;alter system kill session '29,5497' immediate;


我自己按照上面的做了,但是好像没有反应,于是就想直接把DB停掉,在sqlplus 下面shutdown immediate;

结果还是要等很久,不过所幸的是最后执行成功,再重启DB 数据都还好,这中间我看CPU的wait值很高,应该是在回滚刚才已经执行的命令,这里一定要耐心点 让DB跑完,不然很有可能导致数据库无法启动的情况,

下面总结在Oracle里面要杀掉一个process的做法(以下是在PL/SQL Developer里面运行):
select * from v$session;
这里的输出结果有一个栏位是PROCESS, 这个也是对应到系统的PID

alter system kill session 'SID,SERIAL#' immediate;

如果有必要可以直接在系统的层面kill掉进程
ps -ef|grep PROCESS

kill -9 PROCESS


下面总结在DB2里面要杀掉一个process的做法(直接在user@hostname $ 命令提示符下运行):
db2 list application show detail
db2 force application application-handle 
such as:
db2 "force application(543)"

The following example forces two users, with application-handle values of 41408 and 55458, to disconnect from the database:

   db2 "force application ( 41408, 55458 ) "

阅读(6606) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~