溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Oracle中ORACLE_SID,INSTANCE_NAME,DB_NAME幾個(gè)名詞的區(qū)別

發(fā)布時(shí)間:2020-08-11 21:36:02 來源:網(wǎng)絡(luò) 閱讀:7414 作者:anranran 欄目:關(guān)系型數(shù)據(jù)庫

同事項(xiàng)目用到 Oracle,向我問起這些內(nèi)容,雖本人忝列 OCP,但那是6年前的事了,這幾年工作繁重,基本做了清零,受同事之托重新梳理了一遍。


涉及到的名字包括如:DB_NAME,DB_DOMAIN,ORACLE_SID,INSTANCE_NAME, SERVICE_NAME 等。


提起這些名字,首先要理解 ORACLE 的邏輯架構(gòu),我們通常說的可以訪問的ORACLE DB。其實(shí)兩部分組成:實(shí)例(包括一組進(jìn)程,和SGA內(nèi)存等) + 物理介質(zhì)。介質(zhì)包括控制文件,數(shù)據(jù)文件,日志文件,參數(shù)文件等。實(shí)例進(jìn)程就是一堆操作物理介質(zhì)的進(jìn)程。再者實(shí)例進(jìn)程可以不掛載(mount)任何物理介質(zhì),這時(shí)的實(shí)例叫 idle instance.


上面的名字先找簡(jiǎn)單的說:DB_NAME。這兩個(gè)東西創(chuàng)建數(shù)據(jù)庫時(shí)指定,而且最具穩(wěn)定性,DB_NAME遍布在數(shù)據(jù)文件,日志文件,參數(shù)文件中,99.9%情況下不會(huì)也不需要去變他。(雖然現(xiàn)在版本也可以修改了)。


可以把他理解成物理介質(zhì)的標(biāo)記,這些物理介質(zhì)都屬這個(gè)DB。至于DB_DOMAIN只是為好分布式管理加的一個(gè)標(biāo)識(shí)而已,意義不大,知道有這個(gè)東西即可。


ORACLE_SID:一般ORACLE_SID作環(huán)境變量用,他是個(gè)操作系統(tǒng)層面的東西, 最常見的兩個(gè)用處:

決定Oracle實(shí)例 進(jìn)程的名字,在linux下看,Oracle相應(yīng)的進(jìn)程,會(huì)發(fā)現(xiàn)都綴有ORACLE_SID。

定位Oracle的啟動(dòng)參數(shù)文件,Oracle在啟動(dòng)時(shí)要尋找其配置文件(目前以這個(gè)順序查找spfile<ORACLE_SID>.ora -> spfile.ora -> init<ORACLE_SID>.ora)。

Oracle啟動(dòng)之后,這個(gè)參數(shù)也沒多大用處了。

注: 相同Oracle_HOME下,ORACLE_SID要不同,不同Oracle_HOME下,可相同。


INSTANCE_NAME:DB_NAME是物理介質(zhì)的標(biāo)識(shí),INSTANCE_NAME就是實(shí)例進(jìn)程的標(biāo)識(shí)。

對(duì)ORACLE數(shù)據(jù)庫,非RAC情況下,物理介質(zhì)可以被任意實(shí)例進(jìn)程掛載(mount)和打開(open)

但同一時(shí)間,只能有一個(gè)實(shí)例進(jìn)程打開他。 RAC情況下,則允許多個(gè)實(shí)例進(jìn)程打開相同的物理介質(zhì)。

1+1變成了n+1,也就是說RAC情況下,多個(gè)實(shí)例對(duì)應(yīng)著同一個(gè)物理介質(zhì)。


JAVAEE同學(xué)都記得JDBC的連接串為:jdbc:oracle:thin:@<host>:<port>:<SID> 

這個(gè)SID就是INSTANCE_NAME。數(shù)據(jù)庫連接,其實(shí)是連接到實(shí)例進(jìn)程。大多數(shù)時(shí)候我們都當(dāng)成了ORACLE_SID, 只是因?yàn)槟莻€(gè)時(shí)候他們相同了。(關(guān)于各個(gè)參數(shù)的default值問題,這里不說子,碼字累)。


似乎有INSTANCE_NAME+DB_NAME已經(jīng)完美的解決的實(shí)體的定位問題。直到RAC的出現(xiàn),打破了這一寧靜。出了多個(gè)實(shí)例同時(shí)打開同一個(gè)DB_NAME的情況。那個(gè)上面的JDBC的連接串就不好用了,這時(shí)SERVICE_NAME橫空出世。

簡(jiǎn)單的說,SERVICE_NAME代表整個(gè)數(shù)據(jù)庫(進(jìn)程+DB),一個(gè)SERVICE_NAME下面可以有多個(gè)實(shí)例,所以無論是RAC,還是單例數(shù)據(jù)庫, jdbc:oracle:thin:@<host>:<port>:<SERVICE_NAME>都可以正常連接。 


SERVICE_NAME怎么發(fā)揮做的呢,我們知道Oracle監(jiān)聽在1521端口,因?yàn)榇嬖谝粋€(gè)監(jiān)聽器。在ORACLE實(shí)例啟動(dòng)時(shí),PMON進(jìn)程會(huì)將該實(shí)例注冊(cè)到這個(gè)監(jiān)聽器上,當(dāng)前也所括其所屬性的服務(wù)名,這種叫動(dòng)態(tài)注冊(cè),可能不易理解SERVICE_NAME(可以用lsnrctl status命令查看存在的service及instance),看一個(gè)靜態(tài)注冊(cè)的listener.ora:

SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
   (SID_NAME = ORCL) ---這里為INSTANCE_NAME
   (ORACLE_HOME = /mydatafile2/app/oracle/oracle/product/11.2.0/db_1)
   (GLOBAL_DBNAME=WOO.COM) ---這里為SERVICE_NAME。
  )
)

連接到這個(gè)SERVICE,監(jiān)聽器就會(huì)按一定算法將連接負(fù)載到相應(yīng)的實(shí)例上。

綜上看:訪問數(shù)據(jù)庫關(guān)注的大多為Instance_name和service_name.  

 而管理數(shù)據(jù)庫用到ORACLE_SID和DB_NAME

先寫這么多吧,后面再補(bǔ)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI