Oracle查询session连接数和inactive

Posted 唯一

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle查询session连接数和inactive相关的知识,希望对你有一定的参考价值。

-----############oracle会话和进程################--------------
--查询会话总数
select count(*) from v$session;
--查询进程总数
select count(*) from v$process;
--查询哪些应用的连接数此时是多少
select b.MACHINE, b.PROGRAM , count(*) from v$process a, v$session b
where a.ADDR = b.PADDR and b.USERNAME is not null group by b.MACHINE ,
b.PROGRAM order by count(*) desc;
--查询是否有死锁 如果查询结果为no rows selected,说明数据库中没有死锁。否则说明数据库中存在死锁。
select * from v$locked_object;

接下来说明一下会话的状态:
1.active 处于此状态的会话,表示正在执行,处于活动状态。
2.killed 处于此状态的会话,表示出现了错误,正在回滚,当然,也是占用系统资源的。
还有一点就是,killed的状态一般会持续较长时间,而且用windows下的工具pl/sql developer来kill掉,
是不管用的,要用命令:alter system kill session ‘sid,serial#‘ ;
3.inactive 处于此状态的会话表示不是正在执行的,比如select语句已经完成。
我一开始以为,只要是inactive状态的会话,就是该杀,为什么不释放呢。
其实,inactive对数据库本身没有什么影响,但是如果程序没有及时commit,那么就会造成占用过多会话。解决inactive的方法最好的就是在oracle中直接设置超时时间。


















以上是关于Oracle查询session连接数和inactive的主要内容,如果未能解决你的问题,请参考以下文章

查看oracle连接数和会话情况

转--oracle查看允许的最大连接数和当前连接数等信息

oracle如何查询当前连接用户的详细信息

oracle 会话和事务的区别

怎样查看oracle当前的连接数

怎样查看oracle当前的连接数