oracle 10g安装在windows 2003 32位操作系统,连接数到120个就不能连接,报ora12518

 

服务器IBM XSERVER,内存:4G
oracle 数据库配置的主要参数如下:
processes                         integer     800
sessions                             integer     885
pga_aggregate_target                 big integer 350M
sga_max_size                      big integer 1256M
sga_target                         big integer 1152M
shared_pool_size                   big integer 400M
large_pool_size                   big integer 16M

数据库配置的连接数是800个,但是现在当oracle的连接数达到250个时候,其他的客户端就无法再连接上oracle服务器了,报个错:ORA-12518: TNS: 监听程序无法分发客户机 ;
但是已经连接上数据库的应用还可以正常应用,就是其他没连上的就再也连不上了,除非已有的连接有退出的,其他的才能再联上,就是可连接的总数是250个;
上网查:说是在可以在listener.ora中加入一行: direct_handoff_ttc_<listener name>=off,但是依旧不成;
这期间我们尝试着把
pga_aggregate_target 改成200或者500等,结果是一样的;
sga_target改成800m后,结果数据库就起不来了,提示说要不能小于1024m;

后来查到有可能是oracle 10g for win32的一个bug,上网下了补丁,打完补丁后的版本是:10.2.0.3);还怀疑是不是windows 2003的tcp连接数不够,上网查说好像是有这毛病,下了个2003的补丁,把tcp连接数扩到了1000,结果能够达到可以有350个并发连接,但是再多就又连不上了;
现在就是不太清楚究竟是什么参数配置的不合适,(不管是oracle10g的,还是windows 2003的),才会造成实际上没有达到oracle设置的最大连接数时就不能连接了;

又后来,我们怀疑是不是windows 2003 32位的问题,于是就装了个64位的windows 2003,同样版本的oracle 10g,装好后就把连接数process参数配置成800,然后做连接测试,一直可以有800个session连接上来,到现在为止,可以大致总结出症结所在了,就是我们装的这个windows 2003 server(31位)的操作系统,在安装oracle 10g(10.2.0.1-10.2.0.3)时 有问题,连接数不能达到系统配置的那么大;可以采用64位的替代。但是我在想,究竟为什么windows 2003 server(31位)的操作系统+oracle 10g数据库连接数会有限制,有没有什么办法,修改一下2003的配置或者oracle 10g的配置, 就可解决掉这个问题,

 

解决方案二、

解决方案:

 

一、修改oracle参数

1、原有参数 注明:红色为原有参数,蓝色为增加的参数

#pga_aggregate_target=67108864

#processes=500

#sessions=555

# pga_aggregate_target此参数是扩大并发连接数占用内存大小。

# 可调整此参数,放大或缩小,同时影响并发数量。

# 公式: 约=可按照并发数量*4M

pga_aggregate_target=720M

# processes、sessions是扩大并发连接数,是同时使用。

# 公式: sessions = processes *1.1 +5

processes=600  

sessions=665

2、在监听参数文件LISTENER.ORA 文件中增加参数

direct_handoff_ttc_listener = off

3、重新启动数据库服务。

二、1、修改Windows系统中Boot.ini文件

/3GB /PAE

说明:修改操作系统中Boot.ini文件,可以使oracle使用更多的内存空间。

2、修改用户组策略中锁定内存页大小权限。

参数修改完毕问题解决。

3、重启计算机。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值