同事項目用到 Oracle,向我問起這些內(nèi)容,雖本人忝列 OCP,但那是6年前的事了,這幾年工作繁重,基本做了清零,受同事之托重新梳理了一遍。
成都創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、漢南網(wǎng)絡(luò)推廣、成都微信小程序、漢南網(wǎng)絡(luò)營銷、漢南企業(yè)策劃、漢南品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供漢南建站搭建服務(wù),24小時服務(wù)熱線:13518219792,官方網(wǎng)址:jinyejixie.com
涉及到的名字包括如:DB_NAME,DB_DOMAIN,ORACLE_SID,INSTANCE_NAME, SERVICE_NAME等。
提起這些名字,首先要理解 ORACLE 的邏輯架構(gòu),我們通常說的可以訪問的ORACLE DB。其實兩部分組成:實例(包括一組進(jìn)程,和SGA內(nèi)存等) + 物理介質(zhì)。介質(zhì)包括控制文件,數(shù)據(jù)文件,日志文件,參數(shù)文件等。實例進(jìn)程就是一堆操作物理介質(zhì)的進(jìn)程。再者實例進(jìn)程可以不掛載(mount)任何物理介質(zhì),這時的實例叫 idle instance.
上面的名字先找簡單的說:DB_NAME。這兩個東西創(chuàng)建數(shù)據(jù)庫時指定,而且最具穩(wěn)定性,DB_NAME遍布在數(shù)據(jù)文件,日志文件,參數(shù)文件中,99.9%情況下不會也不需要去變他。(雖然現(xiàn)在版本也可以修改了)。
可以把他理解成物理介質(zhì)的標(biāo)記,這些物理介質(zhì)都屬這個DB。至于DB_DOMAIN只是為好分布式管理加的一個標(biāo)識而已,意義不大,知道有這個東西即可。
ORACLE_SID:一般ORACLE_SID作環(huán)境變量用,他是個操作系統(tǒng)層面的東西, 最常見的兩個用處:
決定Oracle實例 進(jìn)程的名字,在linux下看,Oracle相應(yīng)的進(jìn)程,會發(fā)現(xiàn)都綴有ORACLE_SID。
定位Oracle的啟動參數(shù)文件,Oracle在啟動時要尋找其配置文件(目前以這個順序查找spfile<ORACLE_SID>.ora -> spfile.ora -> init<ORACLE_SID>.ora)。
Oracle啟動之后,這個參數(shù)也沒多大用處了。
注: 相同Oracle_HOME下,ORACLE_SID要不同,不同Oracle_HOME下,可相同。
INSTANCE_NAME:DB_NAME是物理介質(zhì)的標(biāo)識,INSTANCE_NAME就是實例進(jìn)程的標(biāo)識。
對ORACLE數(shù)據(jù)庫,非RAC情況下,物理介質(zhì)可以被任意實例進(jìn)程掛載(mount)和打開(open)
但同一時間,只能有一個實例進(jìn)程打開他。 RAC情況下,則允許多個實例進(jìn)程打開相同的物理介質(zhì)。
1+1變成了n+1,也就是說RAC情況下,多個實例對應(yīng)著同一個物理介質(zhì)。
JAVAEE同學(xué)都記得JDBC的連接串為:jdbc:oracle:thin:@<host>:<port>:<SID>
這個SID就是INSTANCE_NAME。數(shù)據(jù)庫連接,其實是連接到實例進(jìn)程。大多數(shù)時候我們都當(dāng)成了ORACLE_SID, 只是因為那個時候他們相同了。(關(guān)于各個參數(shù)的default值問題,這里不說子,碼字累)。
似乎有INSTANCE_NAME+DB_NAME已經(jīng)完美的解決的實體的定位問題。直到RAC的出現(xiàn),打破了這一寧靜。出了多個實例同時打開同一個DB_NAME的情況。那個上面的JDBC的連接串就不好用了,這時SERVICE_NAME橫空出世。
簡單的說,SERVICE_NAME代表整個數(shù)據(jù)庫(進(jìn)程+DB),一個SERVICE_NAME下面可以有多個實例,所以無論是RAC,還是單例數(shù)據(jù)庫, jdbc:oracle:thin:@<host>:<port>:<SERVICE_NAME>都可以正常連接。
SERVICE_NAME怎么發(fā)揮做的呢,我們知道Oracle監(jiān)聽在1521端口,因為存在一個監(jiān)聽器。在ORACLE實例啟動時,PMON進(jìn)程會將該實例注冊到這個監(jiān)聽器上,當(dāng)前也所括其所屬性的服務(wù)名,這種叫動態(tài)注冊,可能不易理解SERVICE_NAME(可以用lsnrctl status命令查看存在的service及instance),看一個靜態(tài)注冊的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。 ) )
連接到這個SERVICE,監(jiān)聽器就會按一定算法將連接負(fù)載到相應(yīng)的實例上。
綜上看:訪問數(shù)據(jù)庫關(guān)注的大多為Instance_name和service_name.
而管理數(shù)據(jù)庫用到ORACLE_SID和DB_NAME
先寫這么多吧,后面再補(bǔ)。
分享標(biāo)題:Oracle中ORACLE_SID,INSTANCE_NAME,DB_NAME幾個名詞的區(qū)別
轉(zhuǎn)載注明:http://jinyejixie.com/article24/pggcce.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗、、搜索引擎優(yōu)化、自適應(yīng)網(wǎng)站、響應(yīng)式網(wǎng)站、App設(shè)計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)