成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

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

同事項目用到 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)

成都網(wǎng)頁設(shè)計公司
莱西市| 新闻| 离岛区| 易门县| 成安县| 泸定县| 沁源县| 绍兴县| 古丈县| 竹溪县| 新乐市| 金塔县| 禄劝| 台北县| 孝义市| 苍溪县| 长宁县| 阳谷县| 墨江| 定日县| 海宁市| 连南| 金溪县| 隆化县| 衡山县| 宁河县| 怀远县| 鹤庆县| 丰宁| 南召县| 长宁县| 吴堡县| 大关县| 萨迦县| 林芝县| 德钦县| 长沙县| 南召县| 厦门市| 通化市| 滦平县|