oracle进程数过多,Oracle连接数过多释放机制

sqlplus /nolog

打开sqlplus

connect /as sysdba

使用具有dba权限得用户登陆oracle

show parameter resource_limit

显示资源限定是否开启,value为true是开启,为false是关闭

alter system set resource_limit=true

如果未开启,则使用此命令开启资源限定功能

create profile profileName limit connect_time 60 idle_time 30

创建profile文件,profileName任意起,connect_time设置连接超过多少分钟后强制释放,idle_time设置连续不活动的会话超过多少分钟后强制释放

alter user oracleUser profile profileName

将profile文件作用于指定用户

从上周起,服务器Oracle数据库出现问题,用不到半天,就会报maxsession(150)的问题,肯定是数据库的会话超过最大数了。

由于服务器跑的是文件传输应用,占用的请求和会话肯定很大,因此用户数不大就已经让oracle的会话数达到最大值。

处理方式不外乎两种:扩大oracle最大session数以及清除inactive会话,当然还有,就是从数据库连接池和程序bug上面下手。

从各处收集了一些查看当前会话的语句,记录一下:

1.select count(*) from v$session;

select count(*) from v$process;

查看当前总会话数和进程数,这两个视图就是跟会话及进程有关的重要视图啦,信息都是从这里面取的。

2.查询那些应用的连接数此时是多少

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;

3.查询是否有死锁

select * from v$locked_object;

如果查询结果为no rows selected,说明数据库中没有死锁。否则说明数据库中存在死锁。

接下来说明一下会话的状态:

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。

修改ORACLE 中的SESSION和PROCESS

会话sessions和进程pocesses的关系

一个process可以有0个、1个或者多个session,一个session也可以存在若干个process中,并行同样是一个session对应一

个process,主session是coordinator session,每个parallel

process同样会对应数据库里一个单独的session。可以从v$px_session和v$session中验证这点。

连接connects,会话sessions和进程pocesses的关系

每个sql login称为一个连接(connection),而每个连接,可以产生一个或多个会话,如果数据库运行在专用服务器方式,一个会话对应一个服务器进程(process),如果数据库运行在共享服务器方式,一个服务器进程可以为多个会话服务。

Oracle的sessions和processes的数量关系是:sessions=1.1 * processes + 5

下面我们用两种方法修改PROCESS的最大值

一、通过Oracle Enterprise Manager Console在图形化管理器中修改

以系统管理员的身份登入,进入界面 数据库的例程 - 配置 - 一般信息 - 所有初始化参数,修改processes的值

二、在SQLPLUS中修改

以DBA权限登录,修改PROCESS的值(SESSION的值会跟着改);创建pfile;重新启动数据库。输入的SQL命令如下,回显信息省略了

SQL> connect sys/sys as sysdba

SQL> alter system set processes=400 scope = spfile;

SQL> create pfile from spfile;

SQL> shutdown immediate;

SQL> startup

《oracle每日一练》Oracle DBLink连接数过多的问题(Ora-02020)

本文转自Oracle DBLink连接数过多的问题(Ora-02020) 今天在处理资料同步问题,需要将其它几个DB Server的资料同步到一个目地资料库,采用的方式是:DBLink+Job ,然而 ...

Oracle E-Business Suite并发处理机制(Current Processing)

2012年写过一篇关于Oracle E-Business Suite并发管理器的文章,回头看之前总结的内容还是比较单薄,很多点没说到,最近在看这块的内容,索性再写一篇稍微完整的文章来. Oracle ...

atitit.资源释放机制--attilax总结

atitit.资源释放机制--attilax总结 1. .全手工, 1 2. 引用计数, 1 2.1. 成本也显而易见. 1 2.2. 循环引用的问题, 2 2.3. 引用计数方式事实上也有经典的卡顿 ...

linux内存管理及手动释放机制

inux系统中查看内存状态一般都会用到free linux的free命令中,cached和buffers的区别 Free Mem:表示物理内存统计 -/+ buffers/cached:表示物理内存的 ...

Oracle DBLink连接数过多的问题(Ora-02020)

前不久开发人员编译存储时报ORA -02020 错,如下是解决方案步骤.   报错全信息: Error:OR A -04052在查: 找远程对象 NIP.PB_PERADDRESSLIST@DB_NI ...

sql 连接数不释放 ,Druid异常:wait millis 40000, active 600, maxActive 600

Hibernate + Spring + Druid 数据库mysql 由于配置如下

使用jqgrid的C#/asp.net mvc开发者的福音 jqgrid-asp.net-mvc

你是否使用jqgrid? 你是否想在C#/asp.net mvc中使用jqgrid? 那你很可能曾经为了分析jqgrid的request url用fiddler忙活了2个小时.(如果你要使用jqgri ...

客户端安全-xss-2解决方案

1.需求 提供xss解决方案 2.方式 对需要显示在html中的用户代码进行编码 3.处理方案 1.用户的数据到后端前用下面的编码层代码进行编码. function htmlEncodeCharact ...

基于SpringMVC下的Rest服务框架搭建【集成Swagger】

1.需求背景 SpringMVC本身就可以开发出基于rest风格的服务,通过简单的配置,即可快速开发出一个可供客户端调用的rest服务,通常这些服务要不就是用于手机app的开发,要不就是提供给第三方开 ...

android: SQLite创建数据库

SQLite 是一款轻量级的关系型数据库,它的运算速度非常快, 占用资源很少,通常只需要几百 K 的内存就足够了,因而特别适合在移动设备上使用.SQLite 不仅支持标准的 SQL 语法,还遵循了数据 ...

JAVA基础知识之网络编程——-TCP/IP协议,socket通信,服务器客户端通信demo

OSI模型分层 OSI模型是指国际标准化组织(ISO)提出的开放系统互连参考模型(Open System Interconnection Reference Model,OSI/RM),它将网络分为七 ...

纯JS文本比较工具

前段时间由于工作需要写了一个纯JS文本比较工具 在这里与大家分享下 算法有待优化,还希望大家多多指教 先上效果图: 奉上源码(把源码保存为html格式的文件就可以直接运行了):

mysql获取各种日期

select curdate(); --获取当前日期 select last_day(curdate()); --获取当月最后一天. select DATE_ADD(curdate(),interva ...

centos系统修改网络配置注意事项

这也是无意之中发现的,我在做一个远程修改工控机网络配置的程序, 网络配置参数/etc/sysconfig/network-scripts/ifcfg-enp1s0下面,当然名字可能不一样ifcfg-e ...

数据库4m10d作业

Create table student ( Sno char(15) primary key , Sname varchar(10) not null, Sage tinyint , Special ...

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Linux上,Oracle连接数可以通过以下几种方式来释放: 1. 正常断开连接:当客户端应用程序完成对数据库的操作后,应主动关闭Oracle连接。可以使用`sqlplus`或者其他数据库客户端提供的命令来执行`disconnect`或者`exit`来断开连接。 2. 手动释放连接:在Oracle数据库中,通过执行`ALTER SYSTEM KILL SESSION`命令可以手动终止一个会话并释放连接。需要提供会话的`SID`和`SERIAL#`,可以从`V$SESSION`视图中获取相应的信息。 3. 自动释放连接:如果存在长时间空闲的连接,可以通过设置相应的连接空闲时间来自动释放。可以使用`sqlnet.ora`文件中的`SQLNET.EXPIRE_TIME`参数来配置连接的空闲时间。当连接超过该时间没有活动时,Oracle会终止连接并释放资源。 4. 使用连接池:连接池可以提高系统的性能和资源利用率。连接池管理器在后台维护一组可用的数据库连接,应用程序通过连接池管理器获取连接,并在不使用时将连接返回给连接池。连接池会根据预定义的规则来管理连接的创建和释放。 总结来说,释放Linux上的Oracle连接可以通过手动断开连接、手动终止会话、自动释放空闲连接和使用连接池等方式实现。根据具体场景和需求,选择适合的方式来释放连接,以提高系统的性能和资源利用率。 ### 回答2: 在Linux操作系统中,当使用Oracle数据库时,连接数释放可以通过以下几种方式实现: 1. 显式关闭连接:在应用程序代码中,在不再需要连接时,手动调用关闭连接的方法或语句来释放数据库连接。例如,在Java中,可以使用Connection对象的close()方法关闭连接。 2. 自动关闭连接:一些编程语言和框架提供了自动管理数据库连接的机制。通过配置连接池,可以设置连接的最大空闲时间以及最大连接数等参数,当连接空闲时间超过设定的阈值或达到最大连接数时,自动关闭不再使用的连接。 3. 优化应用程序:合理地设计和编写应用程序代码,尽量减少对数据库的频繁连接。例如,可以在应用程序中使用连接池,重复利用已经建立的数据库连接,而不是每次都创建新的连接。这样可以减少连接建立和释放的开销。 4. 使用数据库执行计划:通过分析数据库查询的执行计划,找出效率低下的查询语句或索引,进行优化,减少数据库的负载和连接数。 5. 调整数据库连接参数:根据实际情况,合理地调整数据库连接的参数,以提高连接效率和资源利用率。例如,可以增大数据库连接池的大小,提高数据库的并发处理能力。 总之,释放Linux上的Oracle连接数可以通过手动关闭连接、使用连接池、优化应用程序和调整数据库连接参数等方式来实现,以提高系统性能和资源利用率。 ### 回答3: 在Linux上,Oracle连接数释放主要涉及到两个方面:操作系统级别和数据库级别。 在操作系统级别,可以通过以下几种方式释放Oracle连接数: 1. 杀死进程:通过使用kill命令结合进程ID(PID),可以直接终止特定的连接进程。可以使用命令"ps -ef | grep ora_"获取所有Oracle连接进程的PID,并使用"kill -9 PID"命令终止进程。 2. 重启数据库:通过重启数据库来释放所有连接。可以使用"shutdown"和"startup"命令来关闭和启动Oracle数据库。 在数据库级别,可以通过以下几种方式释放Oracle连接数: 1. 断开会话:在数据库中,可以使用ALTER SYSTEM DISCONNECT SESSION命令断开指定的会话连接。通过指定会话的SID(系统标识符)和SERIAL#(序列号),可以断开相应的连接。例如,使用"ALTER SYSTEM DISCONNECT SESSION 'SID,SERIAL#' IMMEDIATE"命令立即断开连接。 2. 增加共享服务器进程:通过增加共享服务器进程(shared server process),可以扩展连接池的容量。共享服务器架构可以将多个会话连接共享到相对较少的进程中,从而减少连接数并提高资源利用率。 3. 调整连接池参数:可以通过调整数据库的连接池参数来优化连接管理。如设置最大连接数(MAX_CONNECTIONS)和最大共享服务器进程数(MAX_SHARED_SERVERS)等。 需要注意的是,释放连接数可能会影响正在进行的会话和相关业务。因此,在执行任何释放连接数的操作之前,请确保已经完成必要的备份和通知,并在非关键业务时间段执行操作,以确保最小的影响。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值