Oracle監(jiān)聽注冊的實(shí)現(xiàn)
一、靜態(tài)注冊
靜態(tài)注冊就是實(shí)例啟動(dòng)時(shí)讀取listener.ora文件的配置,將實(shí)例和服務(wù)注冊到監(jiān)聽程序。無論何時(shí)啟動(dòng)一個(gè)數(shù)據(jù)庫,默認(rèn)地都有兩條信息注冊到監(jiān)聽器中:數(shù)據(jù)庫服務(wù)器對應(yīng)的實(shí)例和服務(wù)。
靜態(tài)注冊時(shí),listener.ora中的GLOBAL_DBNAME向外提供服務(wù)名,listener.ora中的SID_NAME提供注冊的實(shí)例名。
采取靜態(tài)注冊方法時(shí),listener.ora中的內(nèi)容如下:
SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (SID_NAME = PLSExtProc) (ORACLE_HOME = D:/oracle/product/10.2.0/db_1) (PROGRAM = extproc) ) (SID_DESC = (GLOBAL_DBNAME =orcl) (ORACLE_HOME = D:/oracle/product/10.2.0/db_1) (SID_NAME =orcl) ) (SID_DESC = (GLOBAL_DBNAME =orcl1) (ORACLE_HOME = D:/oracle/product/10.2.0/db_1) (SID_NAME =orcl) ) )
該文件表明數(shù)據(jù)庫是單實(shí)例的,實(shí)例名為orcl,向外提供了兩個(gè)服務(wù):orcl和orcl1
二、動(dòng)態(tài)注冊
動(dòng)態(tài)注冊是在instance啟動(dòng)的時(shí)候PMON進(jìn)程根據(jù)init.ora中的instance_name,service_names兩個(gè)參數(shù)將實(shí)例和服務(wù)動(dòng)態(tài)注冊到listener中。
首先要在init.ora中指定instance_name,service_names兩個(gè)參數(shù)的值。在sqlplus下通過show parameter service_names 和show parameter instance_name可以查看這兩個(gè)參數(shù)的值。
注冊到監(jiān)聽器中的實(shí)例值從init.ora文件中的instance_name參數(shù)取得。如果該參數(shù)沒有設(shè)定值,那么它將取init.ora文件中的db_name的值。
注冊到監(jiān)聽器中的服務(wù)值從init.ora文件中的參數(shù)service_names取得。如果該參數(shù)沒有設(shè)定值,數(shù)據(jù)庫將拼接init.ora文件中的 db_name和db_domain的值來注冊自己。
如果選擇提供service_names值,您可以使用完全限定的名稱(比如 orcl.oracle.com)或縮寫的名稱(比如orcl)。
如果選擇縮寫的名稱并設(shè)置了db_domain參數(shù),注冊到監(jiān)聽器中的服務(wù)將是 service_name值和db_domain值的拼接。
例如下面的設(shè)置將導(dǎo)致服務(wù)orcl.oracle.com被注冊到監(jiān)聽器中:
db_domain=oracle.com service_names=orcl
采取動(dòng)態(tài)注冊方法時(shí),listener.ora中的內(nèi)容如下:
SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (SID_NAME = PLSExtProc) (ORACLE_HOME = D:/oracle/product/10.2.0/db_1) (PROGRAM = extproc) ) )
可選擇的是,您可以在service_names參數(shù)中指定多個(gè)服務(wù)值,值之間用逗號格開,這對于共享服務(wù)器配置是很有用的。
動(dòng)態(tài)注冊默認(rèn)只注冊到默認(rèn)的監(jiān)聽器上(名稱是LISTENER、端口是1521、協(xié)議是TCP),如果需要向非默認(rèn)監(jiān)聽注冊,則需要配置local_listener參數(shù)!
如果沒有顯式設(shè)置service_names和instance_name的值,那么僅當(dāng)數(shù)據(jù)庫在監(jiān)聽器運(yùn)行之后啟動(dòng)時(shí),動(dòng)態(tài)注冊才會發(fā)生;在這種情況下,如果監(jiān)聽器后來發(fā)生了重啟,動(dòng)態(tài)注冊信息將會丟失。
顯然,最好在所有的數(shù)據(jù)庫啟動(dòng)之前先啟動(dòng)監(jiān)聽器,這樣就會避免沒有顯式設(shè)置 service_names和instance_name的值時(shí),若重啟監(jiān)聽器帶來的動(dòng)態(tài)注冊信息丟失的情況。為初始化參數(shù)service_names和instance_name設(shè)置顯式的值是個(gè)值得可取的方法和建議。
因?yàn)槿绻O(jiān)聽器在數(shù)據(jù)庫運(yùn)行過程中要重新啟動(dòng),僅當(dāng)你在init.ora文件中顯式地設(shè)置了service_names和instance_name的值時(shí),每個(gè)數(shù)據(jù)庫的PMON進(jìn)程才會在很短的時(shí)間之內(nèi)完成動(dòng)態(tài)注冊。
到此這篇關(guān)于Oracle監(jiān)聽注冊的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Oracle監(jiān)聽注冊內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ORACLE DATAGUARD中手工處理日志v$archive_GAP的方法
從9i以后,oracle dataguard 備庫一般都不需要手工處理丟失的日志,F(xiàn)AL自動(dòng)會幫我們處理,本文主要通過個(gè)案例來講下手工處理丟失的日志的方法。2014-08-08oralce 計(jì)算時(shí)間差的實(shí)現(xiàn)
這篇文章主要介紹了oralce 計(jì)算時(shí)間差的實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2017-05-05Oracle11g r2 卸載干凈重裝的詳細(xì)教程(親測有效已重裝過)
Oracle 的安裝和卸載相較于其他 mysql 要麻煩些,小編特此分享一篇教程關(guān)于Oracle11g 徹底卸載干凈并重新安裝,有需要的朋友可以參考下本文2021-06-06oracle10g 數(shù)據(jù)備份與導(dǎo)入
oracle10g 數(shù)據(jù)備份與導(dǎo)入 實(shí)現(xiàn)方法2009-06-06關(guān)于sql腳本導(dǎo)入Oracle時(shí)重復(fù)生成check約束的問題解決
這篇文章主要給大家介紹了關(guān)于sql腳本導(dǎo)入Oracle時(shí)重復(fù)生成check約束的問題解決方法,文中給出了詳細(xì)的檢查步驟,對大家理解和解決這個(gè)問題具有很好的幫助,需要的朋友們下面來一起看看吧。2017-05-05Navicat設(shè)置Oracle數(shù)據(jù)庫主鍵自增的方法步驟
今天工作的時(shí)候,用到了oracle數(shù)據(jù)庫建表,發(fā)現(xiàn)navicat中對于oracle的支持沒有那個(gè)主鍵自增的按鈕,下面這篇文章主要給大家介紹了關(guān)于Navicat設(shè)置Oracle數(shù)據(jù)庫主鍵自增的方法步驟,需要的朋友可以參考下2023-03-03