天天看點

“無法分發用戶端連接配接”的異常

原因:團隊成員增多,原有資料庫設定不夠用,導緻連接配接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個數

如果第一步解決不了問題。可以進行第二步的操作。

檢視目前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個數。

調整dispatchers個數

alter system set dispatchers='(protocol=tcp)(dispatchers=3)(service=youroracleservicenameXDB)';

--修改dispatchers個數為3.

3. 重新開機oracle。

常見問題處理辦法:

在配置時,有時我們會誤操作。導緻資料無法正常啟動。這時可以從之前備份過的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 <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))

      "DEDICATED" 已建立:1 已拒絕:0 狀态:ready

         LOCAL SERVER

指令執行成功

D:\Documents and Settings\gdy>

繼續閱讀