网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.Oracle9iAS刷新ECperf基准测试记.
.使用Oracle基础架构 在医疗行业运.
.一个将数据分页的存储过程.
.Oracle Berkeley数据库Java版.
.在SQL*PLUS用UltraEdit取代NoteP.
.ExactPapers Oracle 1Z0-023 200.
.Oracle中Decode()函数使用技巧.
.使用智能优化器提高Oracle的性能.
.Oracle CSO:软件应该自我保护.
.关于exception的学习笔记.
.Oracle存储过程中去掉重复字符串.
.oracle系统紧急故障处理方法.
.Linux 进程调度原理.
.Oracle Portal及其门户网站.
.在RedHat AS3上快速安装Oracle数.
.关于Oracle 9i数据库密码重用规则.
.Oracle环境的安全性.
.Oracle数据库-关于外联接.
.Oracle Optimizer:迁移到使用基于.
.Oracle动态并行处理框架及其优越.

如何迅速地杀掉Oralcle的一些session

发表日期:2008-2-9



  一、问题的提出 
  很多的时候我们迅速的杀掉Oralcle的一些session,理由大体如下: 
  
  1、 一些时候,由于我们的数据量很大,相应的事务大并且多,在做shutdown immediate的时候会花费好多的时间,而我们却想用shutdown immediate的方式,而又要把数据库迅速的shutdown下来。 
  
  2、 我们的应用可能使用了会话控制,即在应用的层面控制了一些用户的连接的数量。但有时可能网络发生的瞬断,从而就产生了一些死进程,他们的状态为Inactive的状态。当我们用alter system kill session ‘sid,serial#’进行清除时,这些session的状态又变成了killed,这些就由Pmon进程来慢慢进行清除了,而你恰恰又是个急脾气。 
  
  3、 系统忽然慢了现来,你发现是某个session在做怪,想迅速把它迅速结束掉。 
  
  二、处理方法 
  其实处理方法很简单,是被一些人称为“谋杀”的一种方法。因为一个session会对应着操作系统中相应的一个进程(process),我们不使用Alter system kill session这种方式了,取而代之则是kill的方式,当session的后台进程被杀掉了,便会促使懒散的Pmon进程迅速进行清理工作。 
  
  1、 以一个session做以示例, 
  
  a、 找到你要杀掉的那个session, 并记下paddr 
  
  select sid, username, paddr, status from v$session 
  where username = '用户名' and 
  status = 'INACTIVE'; 
  
  b、 找到这个session所对应的spid 
  
  select * from v$process where addr = '上面查寻的paddr'; 
  c、 杀掉spid所标识的那个进程 
  
  假如你的Oracle是在Unix平台上的,可以用kill。 
  
  $kill spid 
  
  假如你的Oracle是在windown平台上的,有一些的不同,因为windown是以thead来代替process的,需要用到sid和spid两个值,所用的命令也由kill替换为Orakill,格式为rakill sid spid 
  
  C:\>orakill sid  spid 
  
  d、 再查一下v$session,看会话在不在了。 
  
  2、 如何谋杀掉所有的Oracle的用户的进程呢? 
  
  a、windows的环境,执行如下图中的SQL,并把结果存成.bat的文件,比如kill.bat, 执行一下kill.bat就可以了。 
  
  select 'orakill 'sid' 'spid as thread from 
  sys.v_$process p, sys.v_$session s 
  where sid > 6 and 
  p.addr = s.paddr ; 
  
  b、 Unix的环境相对来说就简单多了,执行如下的命令就可以了 
  
  $ ps -efgrep $ORACLE_SIDgrep -v ora_grep LOCAL=NOawk '{print $2}'xargs kill 
  
  然后你再shutdown immediate就很快的了。 
  
  有一些死锁进程,异常退出后用 alter system kill session 'sid, serial#';无法释放会话 可从操作系统直接处理。
上一篇:ora-01034错误解决方法及详细分析 人气:883
下一篇:ORACLE Virtual Private Database 全新体验 人气:596
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐