首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件开发 >

03-01-TMS-Oracel10g最大连市接数的困惑

2012-08-09 
03-01-TMS-Oracel10g最大连接数的困惑oracle10g的默认最大连接数居然是150,很丢人。手动在em控制台修改了初

03-01-TMS-Oracel10g最大连接数的困惑

oracle10g的默认最大连接数居然是150,很丢人。手动在em控制台修改了初始化参数,改成了15000,重启数据库,再查看 process 是 15000,可是隔夜后,查看又变回150了,几次三翻这样,气死人了。

?

2011-2-16 编辑:又上服务器查了一下,processes 是15000,没有变化,但依然报400循环错误,看日志,好象看到有 jdbc 疑似有问题,于是便把 classes1.2 换成了 ojdbc6...,再等待一下,看今天系统会不会崩溃。

2011-2-17 编辑:今天没出问题,难道真是驱动版本的问题?

2011-2-20 编辑:NND 问题还是老问题,需要改 open_cursors 数量从300 改到 30000,保存后,重启数据库后,仍然为 30000,压力测试下实际使用了1600个左右,终于搞明白了。

==============================================

?

?

?

实际上,这个错误的原因,主要还是代码问题引起的。 ? ?
? ora-01000: ? maximum ? open ? cursors ? exceeded. ? ?
? 表示已经达到一个进程打开的最大游标数。 ? ?
? ?
? 这样的错误很容易出现在Java代码中的主要原因是:Java代码在执行conn.createStatement()和conn.prepareStatement()的时候,实际上都是相当与在数据库中打开了一个cursor。尤其是,如果你的createStatement和prepareStatement是在一个循环里面的话,就会非常容易出现这个问题。因为游标一直在不停的打开,而且没有关闭。 ?
? ?
? 一般来说,我们在写Java代码的时候,createStatement和prepareStatement都应该要放在循环外面,而且使用了这些Statment后,及时关闭。最好是在执行了一次executeQuery、executeUpdate等之后,如果不需要使用结果集(ResultSet)的数据,就马上将Statment关闭。 ?
? ?
? 对于出现ORA-01000错误这种情况,单纯的加大open_cursors并不是好办法,那只是治标不治本。实际上,代码中的隐患并没有解除。 ? ?
? 而且,绝大部分情况下,open_cursors只需要设置一个比较小的值,就足够使用了,除非有非常特别的要求。

==============================================

?

在 oracle中,要经常查看process:

查看ORACLE最大进程数
SQL> select count(*) from v$session??#连接数
SQL> Select count(*) from v$session where status='ACTIVE' #并发连接数
SQL> show parameter processes??#最大连接
SQL> alter system set processes = value scope = spfile;重启数据库??#修改连接

unix 1个用户session 对应一个操作系统 process?
而 windows体现在线程

------------------------------------------
修改ORACLE最大进程数
使用sys,以sysdba权限登录:

SQL> show parameter processes;

NAME???????????????????????????????? TYPE??????? VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes????????????????????? integer???? 1
db_writer_processes????????????????? integer???? 1
job_queue_processes????????????????? integer???? 10
log_archive_max_processes??????????? integer???? 1
processes??????????????????????????? integer???? 150

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

系统已更改。

SQL> show parameter processes;

NAME???????????????????????????????? TYPE??????? VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes????????????????????? integer???? 1
db_writer_processes????????????????? integer???? 1
job_queue_processes????????????????? integer???? 10
log_archive_max_processes??????????? integer???? 1
processes??????????????????????????? integer???? 150

SQL> create pfile from spfile;

文件已创建。
?

重启数据库,
?
SQL> show parameter processes;

NAME???????????????????????????????? TYPE??????? VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes????????????????????? integer???? 1
db_writer_processes????????????????? integer???? 1
job_queue_processes????????????????? integer???? 10
log_archive_max_processes??????????? integer???? 1
processes??????????????????????????? integer???? 300

?

--查看当前有哪些用户正在使用数据
SELECT?osuser,?a.username,cpu_time/executions/1000000||'s',?sql_fulltext,machine?
from?v$session?a,?v$sqlarea?b
where?a.sql_address?=b.address?order?by?cpu_time/executions?desc;

?

?

还有可以查询

select?sessions_highwater ?from v$license;

sessions_highwater 记录的是数据库会话曾经达到的最大值

查询数据库自启动以来最大的并发数量

select * from v$license

?

热点排行