oracle账号被锁住通过内存占用情况,找出oracle的session所对应的program

通过内存占用情况,找出oracle的session所对应的program

 

通常情况下,感觉oracle数据库比较慢了,会首先查找AIX操作系统所占内存、CPU最大的process,然后由该process的ID找出对应的oracle session、program,从而进行优化。

     先做如下交代:

 

     AIX操作系统操作:

内存排序:      ps -ealf|head -1;ps -ealf|sort -rn +9|head -50

CPU排序:       ps aux|head -1;ps aux|sort -rn +2|head -20

查找最大资源:ps aux|sort -rn +2|head -20

 

     Oracle两个动态视图:

gv$process:这里的process是操作系统层面的,也是调试oracle数据库的入口;

gv$session:这里才进入到oracle会话,查看所对应的program等等。

          注:v&前面的g表示集群。若有多个实例,则用gv$视图查看更加方便,比如哪个程序跑在哪个实例上。

 

&nbsoracle账号p;    操作步骤:

 

         首先查找所占资源最大的PID所对应的Process的address号:

select addr from gv$process where spid in (6423194)           select addr from gv$process where spid in (1880090 )

 

         然后查找该进程所对应的session,可以查看到对应的username、machine、program等等。

           

select * from gv$session  where paddr in (select addr from gv$process where spid in ( 1880090))

 

 

此条目发表在oracle metalink账号分类目录,贴了标签。将固定链接加入收藏夹。