轉貼:關於資料庫名(db_name)、例項名(instance_name)、ORACLE_SID

orchidllh發表於2005-02-17
作者:jrlee 

關於資料庫名(db_name)、例項名(instance_name)、ORACLE_SID

最近因看到論壇有人問起這方面的東西,將自己的理解加上查閱相關資料整理如下,如果不全或不當的地方,望指正並補全它。

資料庫名(DB_NAME)、例項名(Instance_name)、以及作業系統環境變數(ORACLE_SID)

在ORACLE7、8資料庫中只有資料庫名(db_name)和資料庫例項名(instance_name)。在ORACLE8i、9i中出現了新的引數,即資料庫域名(db_domain)、服務名(service_name)、以及作業系統環境變數(ORACLE_SID)。這些都存在於同一個資料庫中的標識,用於區分不同資料庫的引數。

一、什麼是資料庫名(db_name)?
資料庫名是用於區分資料的內部標識,是以二進位制方式儲存於資料庫控制檔案中的引數,在資料安裝或建立之後將不得修改。資料庫安裝完成後,該引數被寫入資料庫引數檔案pfile中,格式如下:

[code:1:1aaf156970]
.........
db_name="orcl" #(不允許修改)
db_domain=dbcenter.toys.com
instance_name=orcl
service_names=orcl.dbcenter.toys.com
control_file=(...............
.........
[/code:1:1aaf156970]

在每一個執行的ORACLE8i資料庫中都有一個資料庫名(db_name),如果一個伺服器程式中建立了兩個資料庫,則有兩個資料庫名。其控制引數據分屬在不同的pfile中控制著相關的資料庫。

二、什麼是資料庫例項名(instance_name)
資料庫例項名則用於和作業系統之間的聯絡,用於對外部連線時使用。在作業系統中要取得與資料庫之間的互動,必須使用資料庫例項名。例如,要和某一個資料庫server連線,就必須知道其資料庫例項名,只知道資料庫名是沒有用的,與資料庫名不同,在資料安裝或建立資料庫之後,例項名可以被修改。資料庫安裝完成後,該例項名被寫入資料庫引數檔案pfile中,格式如下:
[code:1:1aaf156970]
db_name="orcl" #(不允許修改)
db_domain=dbcenter.toys.com
instance_name=orcl #(可以修改,可以與db_name相同也可不同)
service_names=orcl.dbcenter.toys.com
control_file=(...............
.........
[/code:1:1aaf156970]
資料庫名與例項名之間的關係。
資料庫名與例項名之間的關係一般是一一對應關係,有一個資料庫名就有一個例項名,如果在一個伺服器中建立兩個資料庫,則有兩個資料庫名,兩個資料庫例項名,用兩個標識確定一個資料庫,使用者和例項相連線。
但在8i、9i的並行伺服器結構中,資料庫與例項之間不存在一一對應關係,而是一對多關係,(一個資料庫對應多個例項,同一時間內使用者只一個例項相聯絡,當某一例項出現故障,其它例項自動服務,以保證資料庫安全執行。)

三、作業系統環境變數(ORACLE_SID)
在實際中,對於資料庫例項名的描述有時使用例項名(instance_name)引數,有時使用ORACLE_SID引數。這兩個都是資料庫例項名,它們有什麼區別呢?(經常弄混)
[code:1:1aaf156970]

(ORACLE_SID)
OS

[/code:1:1aaf156970]
上圖表示例項名instance_name、ORACLE_SID與資料庫及作業系統之間的關係,雖然這裡列出的兩個引數都是資料庫例項名,但instance_name引數是ORACLE資料庫的引數,此引數可以在引數檔案中查詢到,而ORACLE_SID引數則是作業系統環境變數。
作業系統環境變數ORACLE_SID用於和作業系統互動。也就是說,在作業系統中要想得到例項名,就必須使用ORACLE_SID。此引數與ORACLE_BASE、ORACLE_HOME等用法相同。在資料庫安裝之後,ORACLE_SID被用於定義資料庫引數檔案的名稱。如:
$ORACLE_BASE/admin/DB_NAME/pfile/init$ORACLE_SID.ora。
定義方法:
[code:1:1aaf156970]
export ORACLE_SID=orcl
[/code:1:1aaf156970]

如果在同一伺服器中建立了多個資料庫,則必然同時存在多個資料庫例項,這時可以重複上述定義過程,以選擇不同例項。

還可以用
[code:1:1aaf156970]
[oracle@Datacent]$ . oraenv
[/code:1:1aaf156970]

來切換不同的ORACLE_SID來通過作業系統來啟動不同的例項(instance)

 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/51862/viewspace-180585/,如需轉載,請註明出處,否則將追究法律責任。

相關文章