方法/步骤
①查询哪些对象被锁:
select object_name,machine,s.sid,s.serial#
from v$locked_object l,dba_objects o ,v$session s
where l.object_id = o.object_id and l.session_id=s.sid;
PS.以上两步,可通过Oracle的管理控制台来执行.
如果利用上面的方法杀死进程后,进程状态虽被置为"killed",但是锁定的资源很长时间没有被释放,那么可以在OS一级再杀死相应的进程(线程)
①首先获得进程(线程)号:
select spid, osuser, s.program
from v$session s,v$process p
①.)在unix上,用root身份执行命令:
orakill是oracle提供的一个可执行命令,语法为:orakill sid thread
其中:
sid:表示要杀死的进程属于的实例名
thread:是要杀掉的线程号,即上面查询出的spid.
举个例子
通过session id (SID) 找到系统进程号 然后kill 进程
SQL select spid from v$process where addr=(select paddr from v$session where rownum=1 and sid=(select userenv('SID') from dual));
SPID
------------------------
spid 系统进程号
kill 掉这个进程 就完了
SQL select sysdate from dual;
select sysdate from dual
*
第 1 行出现错误:
①.、在做Oracle监听程序测试时,发现帐户已经被锁定.
有时,Oracle中造成一些表被死锁或者会话异常退出,如执行了更新记录操作后,既没有commit也没有rollback,网络就断开了,也会造表或记录被锁住,待到超时后才会被解开,那样都会造成应用操作被阻塞.
可以以Oralce管理员权限用户登录Oracle数据,查询到被锁的对象,然后杀除指定的会话.
用下面的语句查询被锁的对象,可以带上更多约束条件,如schemaname等更精确的匹配.
SELECT
a.object_id, a.session_id, b.object_name, c.*
FROM
v$locked_object a, dba_objects b, v$session c
WHERE
a.object_id = b.object_id
AND
a.SESSION_ID = c.sid(+)
杀Seesion的SQL语句语法如下:
alter system kill session 'sid, serial#'
如果要一次性杀死多个会话,一个一个填写sid和serial#十分的繁琐,应该在查询被锁对象的同时拼凑出多条的杀会话语句,以分号分隔,一起复制下来,然后就可以批量的执行了.
拼凑kill语句的方式如下,下面加了一个过滤条件和一个排序,杀除真正关心的表,并且着重注意超时时间过长的会话.
SELECT 'alter system kill session ''' || c.sid || '' || ',' || c.serial# ||''';',
FROM v$locked_object a, dba_objects b, v$session c
WHERE a.object_id = b.object_id
AND a.SESSION_ID = c.sid(+)
AND schemaname = 'Unmi'
ORDER BY logon_time
你遇到过下面类似的情况吗?一个用户进程长期占用资源而不释放,导致Oracle进程占用了系统的大量资源,Oralce系统的效率变得很低.如果简单的关闭重启Oracle
实例,势必影响所有的用户.有没有办法仅仅只Kill掉有问题的用户进程而不用关闭整个Oralce实例呢?答案是可以的,使用Oralce提供的一个名叫Orakill的工具.
大家都知道,Windows
务器的模式,如果你Kill掉ORACLE.EXE这个进程,将导致整个Oracle实例关闭,如同使用Shutdown
abort命令一样.
在NT中如果使用alter system kill
session
'sid,serial#'来清楚会话,在执行之后该会话的状态会变为KILLED,但是有时候这个状态会保持很长时间,直到最后被清除.
如果想更快地从内存中清理这个会话,那么可以在使用了alter
system之后,再在NT中使用Orakill实用程序(该程序随Oracle数据库同时安装)直接清除该会话的线程.
Orakill的使用方法如下:
Dos提示符下:orakill sid thread
说明: sid Oracle的Sid号
thread Oracle的线程id号
首先取得被杀掉的会话的Thread Number:
SET pagesize 100
SET linesize 100
SELECT s.sid AS "Sid", s.serial# AS "Serial#", p.spid AS
"ThreadID",
s.osuser
AS "OSUser", s.program AS "Program"
FROM v$process p, v$session s
WHERE p.addr = s.paddr(+)
ORDER BY s.sid
输出可能如下:
Sid Serial# ThreadID OSUser Program
--- ------- -------- ------ -------
...
然后在命令行窗口执行Orakill命令
orakill的命令帮助如下:
C:orakill
Usage: orakill sid thread
where sid = the Oracle instance to target
thread = the thread id of the thread to kill
The thread id should be retrieved from the spid column of a query
such
as:
SELECT spid, osuser, s.program
WHERE p.addr = s.paddr;
需要注意的是,如果你Kill掉的是Oracle的核心后台线程(DBWR, LGWR, SMON or
PMON),将导致Oracle实例关闭.检查Oracle的核心后台线程的方法如下:
sql:Select vb.name NOME, vp.programe PROCESSNAME,
vp.spid THREADID, vs,sid SID
sql:From v$session vs, v$process vp, v$bgprocess
vb
sql:Where vb.addr
'00' and
sql:vb.paddr = vp.addr and
sql:vp.addr = vs.paddr
查询结果如下:
NOME
PROCESSNAME
THREADID SID
----- ----------------------------------- --------- ------
PMON
ORACLE.EXE
DBW0
LGWR
CKPT
SMON
RECO
SNP0
SNP1
特别提醒,这里的sid指的是oracle的实例号
即
select instance from v$instance;
而且orakill只能用于oracle实例安装在windows上的时候