ORA-12518: TNS: 監聽程序無法分發客戶機連接

源自:http://blog.csdn.net/zhouxinhong/article/details/7396910

在團隊成員增多時,經常出現“無法分發客戶端連接”等問題。在網上搜索一番後,最終解決了該問題,現將解決方案總結如下,以供參考和以後備用。

原因:團隊成員增多,原有數據庫設置不夠用,導致連接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:\pfile.ora' --從D:\pfile.ora(之前備份出來的pfile文件)創建系統配置信息。

將提示創建文件成功。

這時,啓動數據庫即可

SQL> startup

 

解決方案:

無法連接到數據庫實例: ORA-12518: TNS: 監聽程序無法分發客戶機連接

可能是如下的原因:客戶連接到監聽器後,監聽器把客戶重定向到調度程序端口(很可能不是1521端口),由於操作系統問題,這些連接會被拒絕。
要解決這個問題,只需要在LISTENER。ORA的頭部加入這一行DIRECT_HANDOFF_TTC_LISTENER = OFF 即可。

1:根據搜索到的原因,我們在LISTENER。ORA頭部加入這一行

--------------------------------------------------------------------------------
# listener.ora Network Configuration File: D:\oracle\product\10.2.0\db_1\NETWORK\ADMIN\listener.ora
# 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
(ADDRESS=(PROTOCOL=tcps)(HOST=netplus)(PORT=1934))
"D000" 已建立:7 已被拒絕:0 當前: 6 最大: 1002 狀態: ready
DISPATCHER
(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
(ADDRESS=(PROTOCOL=tcps)(HOST=netplus)(PORT=1934))
"D000" 已建立:7 已被拒絕:0 當前: 6 最大: 1002 狀態: ready
DISPATCHER
(ADDRESS=(PROTOCOL=tcp)(HOST=netplus)(PORT=1933))
"DEDICATED" 已建立:1 已拒絕:0 狀態:ready
LOCAL SERVER
命令執行成功

D:\Documents and Settings\gdy>

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章