oracle監聽器動態註冊於靜態註冊的區別

1, oracle 10g 用netca方式創建的都默認爲動態註冊方式
2,若是想改成靜態註冊的方式則在listener.ora 中加入以下內容便可
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = PLSExtProc)
(ORACLE_HOME = /u01/app/oracle/product/10.2.0/db_1)
(PROGRAM = extproc)
)
(SID_DESC =
(SID_NAME = JEFF )
(ORACLE_HOME = /u01/app/oracle/product/10.2.0/db_1) --就這一段
(GLOBAL_DBNAME = jeff)
)
) 數據庫

LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = r1)(PORT = 1521))
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))
)
)

3,二者的區別
即靜態註冊,listener不知道實例的狀態,只有在進程經過其鏈接數據庫時才能知道,若是你想使用遠程管理數據庫就使用靜態監聽
動態註冊:listener實時的都知道實例的狀態,數據庫在關閉的時候會動態的從listener中註銷,因此遠程管理數據庫的啓動和中止就不行了。

4,如何判斷是靜態註冊仍是動態註冊
(1) 能夠經過配置文件判斷 oracle

動態註冊 app

SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (PROGRAM = extproc)
      (SID_NAME = PLSExtProc)
      (ORACLE_HOME = D:\oradata\orcl)
    )
  ) tcp

靜態註冊 this

SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (PROGRAM = extproc)
      (SID_NAME = PLSExtProc)
      (ORACLE_HOME = D:\oradata\orcl)
    )
    (SID_DESC =
      (GLOBAL_DBNAME = orcl)
      (ORACLE_HOME = D:\oradata\orcl)
      (SID_NAME = ORCL)
    )
    (SID_DESC =
      (GLOBAL_DBNAME = orcl1)
      (ORACLE_HOME = D:\oradata\orcl)
      (SID_NAME = ORCL)
    )
  ) spa

經過查看雖然能夠大體看出,可是這種方法並不能和明確的現實數據庫在運行時的實際狀況 進程


(2) lsnrclt status

----靜態註冊是這樣的 都是unknow
Services Summary...
Service "PLSExtProc" has 1 instance(s).
Instance "PLSExtProc", status UNKNOWN, has 1 handler(s) for this service...
Service "jeff" has 1 instance(s).
Instance "JEFF", status UNKNOWN, has 1 handler(s) for this service...
The command completed successfully ip

 

-----動態註冊是這樣的
Services Summary...
Service "JEFF" has 1 instance(s).
Instance "JEFF", status READY, has 1 handler(s) for this service...
Service "JEFFXDB" has 1 instance(s).
Instance "JEFF", status READY, has 1 handler(s) for this service...
Service "JEFF_XPT" has 1 instance(s).
Instance "JEFF", status READY, has 1 handler(s) for this service...
Service "PLSExtProc" has 1 instance(s).
Instance "PLSExtProc", status UNKNOWN, has 1 handler(s) for this service...
The command completed successfully tls


3,有時候會碰到即便listener起來也不能鏈接到數據庫的狀況 。會報一個ORA-12514 , 配置

運行lsnrctls status 是這個樣子的 ,說明沒有服務沒有註冊進來

Listening Endpoints Summary...
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=r1)(PORT=1521)))
(DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC0)))
Services Summary...
Service "PLSExtProc" has 1 instance(s).
Instance "PLSExtProc", status UNKNOWN, has 1 handler(s) for this service...
The command completed successfully

解決方法:
alter system register; ---手動將服務註冊到listener中

 

4,若是我想使用動態註冊,可是又不想使用1521端口怎麼辦 這個時候咱們就要用到 local_listener這個參數了,當你使用的是其餘端口好比說是1522端口,那麼只要配置這個參數就ok了。 SQL> alter system set local_listener='(DESCRIPTION = 2 (ADDRESS = (PROTOCOL = TCP)(HOST = xys)(PORT = 1522)) 3 )';

相關文章
相關標籤/搜索