oracle连接数杀了,oracle 连接数不够用

一、扩大oracle最大session数以及清除inactive会话。 kill

没有被回收的session

二、如果经常出现不够用。应从数据库连接池与程序bug

解决,比如jdbc连接不关闭,多次实例化spring中ClassPathXmlApplicationContext

等程序问题。

1、查询数据库当前进程的连接数:

select

count(*) from v$process;

2、查看数据库当前会话的连接数:

select

count(*) from v$session;

3、查看数据库的并发连接数:

select

count(*) from v$session where status='ACTIVE';

4、查看当前数据库建立的会话情况:

select

sid,serial#,username,program,machine,status from

v$session;

5、查询数据库允许的最大连接数:

select

value from v$parameter where name = 'processes';

6、查询oracle版本

select * from v$instance

7、查询是否有死锁

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中直接设置超时时间,也是有两种方法,区别暂时还不清楚:

1.修改sqlnet.ora文件,新增expire_time=x(单位是分钟)

我的sqlnet.ora位置在D:\oracle\ora92\network\admin

2.通过ALTER PROFILE DEFAULT LIMIT IDLE_TIME 10;

命令修改,记得重启下oracle。

程序的问题逐一分析程序中是否有jdbc没有释放的,连接池等。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle数据库的连接数上限通常由多个因素决定,包括操作系统限制、数据库实例参数配置以及并发控制策略。以下是一些关键点: 1. **操作系统的限制**:每个用户账户或进程在操作系统层面上可能有一个默认的最大打开文件(通常是套接字)数目。这可以通过`/etc/security/limits.conf`文件或`ulimit`命令来调整。 2. **Oracle参数设置**: - `DB_BLOCK_SIZE`: 这个参数影响到数据块大小,间接影响了打开的表空间和数据文件数量,从而影响最大连接数。 - `MAX_OPEN_FILES`: Oracle实例参数,设置了单个服务器进程能同时打开的文件数量。这个值可以通过`SQL*Plus`或`ALTER SYSTEM`命令修改。 - `PCT_IOSIZE`: 可能会影响内存中保持的会话数,如果分配过大可能导致连接数受限。 3. **监听器配置**:Oracle listener的`Maximum Sessions`参数也对最大连接数有所影响。 4. **资源池管理**:在Oracle 12c及以上版本,使用Resource Manager时,你可以设置资源池的连接上限。 5. **连接池大小**:如果你使用的是连接池技术,如Oracle Connection Pooling Framework (CPFC) 或第三方工具,那么池的大小也会制约实际可达到的连接数。 为了获得特定环境下的Oracle连接数上限,你需要查看数据库实例的配置文件,比如`init.ora`或`spfile`,并检查相关的系统变量。此外,监控工具如`V$SESSION`视图可以帮助你实时观察当前的连接状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值