Oracle的KILL锁表及清除sess…
来源:互联网 发布:手机淘宝可以注册账号 编辑:程序博客网 时间:2024/06/05 15:13
Oracle的KILL锁表及清除session方法
2010-03-1710:00:43|
一、处理过程
二、使用了相关表的基本介绍
- V$LOCKED_OBJECT中的列说明:
XIDUSN:回滚段号
XIDSLOT:槽号
XIDSQN:序列号
OBJECT_ID:被锁对象ID
SESSION_ID:持有锁的sessionID
ORACLE_USERNAME:持有锁的Oracle 用户名
OS_USER_NAME:持有锁的操作系统 用户名
PROCESS:操作系统进程号
LOCKED_MODE:锁模式
- dba_objects的列说明(网上找的,懒得翻译了^_^)
OWNER
Usernameof the owner of the object OBJECT_NAME Name ofthe object SUBOBJECT_NAME Name ofthe sub-object (for example,partititon) OBJECT_ID Objectnumber of the object DA TA_OBJECT_ID Objectnumber of the segment which contains the object OBJECT_TYPE Type ofthe object CREATED Timestampfor the creation of the object LAST_DDL_TIME Timestampfor the last DDL change (including GRANT and REVOKE) to theobject TIMESTAMP Timestampfor the specification of the object STATUS Status ofthe object TEMPORARY Can thecurrent session on ly see da ta that it place in thisobject itself? GENERATED Was thename of this object system generated? SECONDARY Is this asecondary object created as part of icreate for domain indexes? - v$session的说明
V$SESSION是基础信息视图,用于找寻用户SID或SADDR
常用列:
SID:SESSION标识
SERIAL#:如果某个SID又被其它的session使用的话则此数值自增加(当一个SESSION结束,另一个SESSION开始并使用了同一个SID)。
AUDSID:审查sessionID唯一性,确认它通常也用于当寻找并行查询模式
USERNAME:当前session在oracle中的用户名。
STATUS:这列用来判断session状态是:
Achtive:正执行SQL语句(waiting for/using a resource) Inactive:等待操作(即等待需要执行的SQL语句) Killed:被标注为删除 - v$process视图
v$process视图包含当前系统Oracle运行的所有进程信息。常被用于将Oracle或服务进程的操作系统进程ID与数据库session之间建立联系。
常用列:
ADDR:进程对象地址
PID:oracle进程ID
SPID:操作系统进程ID
详解:
一些ORACLE中的进程被杀掉后,状态被置为"killed",但是锁定的资源很长时间不释放,有时实在没办法,只好重启数据库。但是shutdownimmediate又怕可能进程杀不掉会一直停留在shutdown immediate,直接shutdownabort又怕损坏数据库。
现在提供一种方法解决这种问题,那就是在ORACLE中杀不掉的,在OS一级再杀。
一些ORACLE中的进程被杀掉后,状态被置为"killed",但是锁定的资源很长时间不释放,有时实在没办法,只好重启数据库。但是shutdownimmediate又怕可能进程杀不掉会一直停留在shutdown immediate,直接shutdownabort又怕损坏数据库。
现在提供一种方法解决这种问题,那就是在ORACLE中杀不掉的,在OS一级再杀。
1.下面的语句用来查询哪些对象被锁:
SELECT S.USERNAME,S.OSUSER,S.SID,S.SERIAL#,P.SPID FROM V$SESSIONS,V$PROCESS
P WHERE S.PADDR=P.ADDR AND S.USERNAME IS NOT NULL;
2.下面的语句用来杀死一个进程:
alter system kill session 'sid,serial#';
【注】以上两步,可以通过Oracle的管理控制台来执行。
如果出现题目的错误,可以
select a.spid,b.sid,b.serial#,b.username from v$process a,v$sessionb where a.addr=b.paddr and b.status='KILLED' ;
3.如果利用上面的命令杀死一个进程后,进程状态被置为"killed",但是锁定的资源很长时间没有被释放,那么可以在os一级再杀死相应的进程(线程),首先执行下面的语句获得进程(线程)号:
select spid, osuser, s.program from v$session s,v$process pwhere
s.paddr=p.addr and s.sid=33 (33就是上面的sid)
4.在OS上杀死这个进程(线程):
1)在unix上,用root身份执行命令:
#kill -9 12345(即第3步查询出的spid)
2)在windows(unix也适用)用orakill杀死线程,orakill是oracle提供的一个可执行命令,语法为:
orakill sid thread
其中:
sid:表示要杀死的进程属于的实例名
thread:是要杀掉的线程号,即第3步查询出的spid。
例:c:>orakill orcl 12345
Ps:这里要注意的是kill OS进程是在服务端操作,而不是你程序所在客户机。
- Oracle的KILL锁表及清除sess…
- Oracle的KILL锁表及清除sess…
- Oracle的KILL锁表及清除sess…
- Oracle的KILL锁表及清除session方法
- Oracle的KILL锁表及清除session方法
- Oracle的KILL锁表及清楚session方法
- 查看oracle被锁的表及kill
- Oracle锁表查询及解锁kill
- Oracle锁表查询及解锁kill
- Oracle锁表查询及解锁kill进程简介
- Oracle锁表查询及解锁kill进程简介
- Oracle 锁表查询及解锁kill进程
- Oracle锁表查询及解锁kill进程简介
- oracle锁表查询及解锁kill进程
- Oracle锁表查询及解锁kill进程简介
- ORACLE快速彻底Kill掉的会话,防止锁表
- oracle的kill session
- ORACLE BUFFERCACHE及清除
- 如何使用JTree
- XManager5连接CentOS7
- Linux7.3.1611安装Oracle11g
- CentO7安装部署应用服务器—resin
- 【数据结构实验八】排序
- Oracle的KILL锁表及清除sess…
- js 获取浏览器类别
- 1.android studio配置----Terminal命令窗口
- Oracle的KILL锁表及清除sess…
- Oracle的KILL锁表及清除sess…
- IllegalArgumentException: Service Intent must be explicit
- return *(int*)b-*(int*)a意思
- html中id与name,css中id与class
- Overlay网络