ORA-12518 TNS 监听程序无法分发客户机连接

ORA-12518: TNS: 监听程序无法分发客户机连接
在团队成员增多时,经常出现“无法分发客户端连接”等问题。在网上搜索一番后,最终解决了该问题,现将解决方案总结如下,以供参考和以后备用。
原因:团队成员增多,原有数据库设置不够用,导致连接plsql和启动tomcat时经常抛出“无法分发客户端连接”的异常。
解决方案:
第一步:调整process和session值
1. 检查process和session是否够用。
a)使用plsql连接到oracle,查看process进程数:
select count(*) from v$process; --取得数据库目前的进程数。
安息香缩合select value from v$parameter where name = 'processes';    --取得进程数的上限。
b)查看session会话数:
select count(*) from v$session; --取得数据库目前的会话数。
select value from v$parameter where name = 'sessions'; --取得会话数的上限。
查看当前process和sessions是否接近上限值。若接近,可以将其增大。
2. 调整这两个参数值大小。
系统进程数process和系统会话数session之间存在一个关系:
process数=session数*1.1+5
我们在配置时参考该规律进行设定。
a)  修改process值
alter system set processes=1000 scope=spfile;  --将process值改为1000
b)  修改session值
alter system set sessions=1105 scope=spfile;    --将sessions值改为1105
3. 备份pfile,重启oracle
a) 修改完成后,备份pfile
create pfile from spfile;          --从spfile(运行时配置)创建pfile(系统配置)
c)  重启oracle
重启的方法有很多种,可以重启oracle服务,或者重启数据库。Windows下可以直接重启服务。
第二步:修改dispatchers个数
如果第一步解决不了问题。可以进行第二步的操作。
1.查看当前dispatchers个数,和dispatchers使用率
select name,busy,status,accept,idle from v$dispatcher;  --查看当前dispatchers个数和部分
信息。一般默认安装的库只有一个。
select name,(busy/(busy+idle))*100 "busy rate%" from v$dispatcher; --查看dispatchers使用率坏疽
如果使用率大于50%,则要考虑增加dispatchers个数。
1.调整dispatchers个数
alter system set dispatchers='(protocol=tcp)(dispatchers=3)(service=youroracleservicenameXDB)';
--修改dispatchers个数为3.
3. 重启oracle。
常见问题处理办法:
1.在配置时,有时我们会误操作。导致数据无法正常启动。这时可以从之前备份过的pfile来恢复oracle系统设置。
sqlplus /nolog  --连接到数据库
出现连接提示光标
SQL> conn / as sysdba    --以windows用户以sysdba身份登录,便于操作数据库
SQL> create spfile from pfile= 'D:\a'    --从D:\a(之前备份出来的pfile文件)创建系统配置信息。
将提示创建文件成功。
这时,启动数据库即可
30过氧化氢SQL> startup
 
解决方案:
无法连接到数据库实例: ORA-12518: TNS: 监听程序无法分发客户机连接
可能是如下的原因:客户连接到后,把客户重定向到调度程序端口(很可能不是1521端口),由于操作系统问题,这些连接会被拒绝。
要解决这个问题,只需要在LISTENER。ORA的头部加入这一行DIRECT_HANDOFF_TTC_LISTENER = OFF 即可。
1:根据搜索到的原因,我们在LISTENER。ORA头部加入这一行
--------------------------------------------------------------------------------
# a Network Configuration File: D:\oracle\product\10.2.0\db_1\NETWORK\a
# Generated by Oracle configuration tools.
DIRECT_HANDOFF_TTC_LISTENER = OFF
SID_LIST_LISTENER =
(SID_LIST =
    (SID_DESC =
      (SID_NAME = PLSExtProc)
      (ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
      (PROGRAM = extproc)
    )
)
LISTENER =
(DESCRIPTION_LIST =
    (DESCRIPTION =
安顺学院学报      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))
    )
    (DESCRIPTION =
可编程控制      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.1)(PORT = 1521))
    )
)
--------------------------------------------------------------------------------
2:执行以下命令重启和EM
--------------------------------------------------------------------------------
lsnrctl stop
lsnrctl start
emctl stop dbconsole
emctl start dbconsole
--------------------------------------------------------------------------------
3:查看状态和登入EM,看到状态,一切正常
--------------------------------------------------------------------------------
D:\Documents and Settings\gdy>lsnrctl service
LSNRCTL for 32-bit Windows: Version 10.2.0.1.0 - Production on 15-7月 -2007 18:2
厦门理工学院陈蕾
8:19
Copyright (c) 1991, 2005, Oracle. All rights reserved.
正在连接到 (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC1)))
服务摘要..
服务 "PLSExtProc" 包含 1 个例程。
例程 "PLSExtProc", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
    处理程序:
      "DEDICATED" 已建立:0 已被拒绝:0
        LOCAL SERVER
服务 "orcl" 包含 1 个例程。
例程 "orcl", 状态 READY, 包含此服务的 3 个处理程序...
    处理程序:
      "D001" 已建立:0 已被拒绝:0 当前: 0 最大: 1002 状态: ready
        DISPATCHER <machine: NETPLUS, pid: 3448>
        (ADDRESS=(PROTOCOL=tcps)(HOST=netplus)(PORT=1934))
      "D000" 已建立:7 已被拒绝:0 当前: 6 最大: 1002 状态: ready
        DISPATCHER <machine: NETPLUS, pid: 3996>
        (ADDRESS=(PROTOCOL=tcp)(HOST=netplus)(PORT=1933))
      "DEDICATED" 已建立:1 已拒绝:0 状态:ready
        LOCAL SERVER
服务 "orcl_XPT" 包含 1 个例程。
例程 "orcl", 状态 READY, 包含此服务的 3 个处理程序...
    处理程序:
      "D001" 已建立:0 已被拒绝:0 当前: 0 最大: 1002 状态: ready
        DISPATCHER <machine: NETPLUS, pid: 3448>
        (ADDRESS=(PROTOCOL=tcps)(HOST=netplus)(PORT=1934))
      "D000" 已建立:7 已被拒绝:0 当前: 6 最大: 1002 状态: ready
        DISPATCHER <machine: NETPLUS, pid: 3996>
        (ADDRESS=(PROTOCOL=tcp)(HOST=netplus)(PORT=1933))

本文发布于:2024-09-21 22:46:43,感谢您对本站的认可!

本文链接:https://www.17tex.com/xueshu/516680.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:连接   无法   数据库   个数
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2024 Comsenz Inc.Powered by © 易纺专利技术学习网 豫ICP备2022007602号 豫公网安备41160202000603 站长QQ:729038198 关于我们 投诉建议