您好,登錄后才能下訂單哦!
同事項(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ǔ)。
免責(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)容。