国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

UNIX 和 WINDOWS2000 上的 ORACLE 的差異

瀏覽:6日期:2023-11-18 19:36:43
Ian Adam, SAIC LtdDavid Stien,;;;;;;;SAIC Ltd翻譯:Fenng;;;;;;; 摘要Oracle是廣為人知的Unix硬件平臺上的領(lǐng)先的數(shù)據(jù)庫系統(tǒng)。ORACLE用戶和治理員因此熟悉Unix平臺上的ORACLE架構(gòu)以及它上面的工具和技巧,并從他們的數(shù)據(jù)庫得到最大的收益。相反,Windows上的ORACLE架構(gòu)就不那么的被廣為了解。這篇文章從一個DBA的角度考察了兩個操作系統(tǒng)之間的要害的異同點。簡介在看了幾本令人失望的這方面的書之后,我們寫了這篇文章。那些書的通病是試圖做太多的事情--在細節(jié)上講述Windows和ORACLE。我們的這篇文章假定讀者熟悉Unix平臺上的ORACLE DBA的工作。因此本文將分析兩個平臺上的ORACLE的要害的差異而不是從頭教你ORACLE的技巧。我們不想把它作為你的一份詳盡的指導(dǎo)或者是手冊的替代品,事實上它可能鼓勵你閱讀一些手冊。作為數(shù)據(jù)庫服務(wù)器平臺,它只會涉及一些Unix和Windows上相關(guān)的優(yōu)點,這就是本文的目的。范例這個例子使用Linux上的ORACLE 8i,實例名字叫作eighti。windows 2000上面的ORACLE 8i的實例名字叫作atei。客戶端對ORACLE的訪問當(dāng)客戶端連接到ORACLE時,通常的來說ORACLE服務(wù)器的平臺與客戶端的應(yīng)用無關(guān)。這實際上很難說清。 ORACLE DBA 和系統(tǒng)治理人員更關(guān)心操作系統(tǒng)平臺,他們有的時候會基于需求(如運行時間和可擴展性)選擇平臺。 更通常的情況下,他們接受(或是接手)給定的平臺并學(xué)習(xí)從中得到最大受益。關(guān)于WINDOWS 2000 值得一提的是Windows 2000是從Windows NT升級而來。在這兩個操作系統(tǒng)之間有很多的相似點,Windows 2000 也有些新的特性。微軟從NT4.0的升級途徑見下表。兩個系統(tǒng)間有很多相似點:-------------------------------------------------------------------------------------NT 4.0;Windows 2000-------------------------------------------------------------------------------------NT 4.0 Workstation;Windows 2000 ProfessionalNT 4.0 ServerWindows 2000 ServerNT 4.0 Enterprise Edition; Windows 2000 Advanced serverUnix ; Windows 2000 Datacenter server-------------------------------------------------------------------------------------ORACLE后臺進程下面這句話對于用過ORACLE的人來說是會很熟悉的:'每一個運行著的ORACLE數(shù)據(jù)庫都對應(yīng)一個ORACLE實例,當(dāng)一個數(shù)據(jù)庫在數(shù)據(jù)庫服務(wù)器(不考慮機器的類型)上啟動的時候,ORACLE分配一塊叫做System Global Area (SGA)的內(nèi)存區(qū)域并啟動一個或者多個ORACLE進程。 SGA和ORACLE進程合起來稱作ORACLE 實例。'――摘自 ORACLE 8i Concepts [4 L Leverenz, 1999]。處理后臺進程是放在首位的,也是不同的操作系統(tǒng)之間最明顯的差異。ORACLE在UNIX上的后臺進程任何連接到UNIX的用戶都可以很輕易的察看ORACLE的后臺進程:% ps -efgrep eightigrep -v greporacle8 18451;;1; 0 16:37:18 ?;;;;;0:00 ora_pmon_eightioracle8 18453;;1; 0 16:37:19 ?;;;;;0:00 ora_dbw0_eightioracle8 18457;;1; 0 16:37:19 ?;;;;;0:04 ora_ckpt_eightioracle8 18461;;1; 0 16:37:19 ?;;;;;0:00 ora_reco_eightioracle8 18455;;1; 0 16:37:19 ?;;;;;0:02 ora_lgwr_eightioracle8 18459;;1; 0 16:37:19 ?;;;;;0:01 ora_smon_eightioracle8 19168 19167; 0 16:43:46 ?;;;;;0:00 oracleeighti (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))最后一行的ORACLE進程與一個SQL*Plus會話相關(guān),其他的進程都是后臺進程。在ORACLE中我們可以通過輸入SQL*Plus會話察看這些進程:SELECT sid, spid, osuser, s.program FROM v$process p, v$session s WHERE p.addr=s.paddr; SID SPID;OSUSER;;PROGRAM ------------------------------------------------------------------- 1 18451;;oracle8;;;oracle@saic02 (PMON) 2 18453;;oracle8;;;oracle@saic02 (DBW0) 3 18455;;oracle8;;;oracle@saic02 (LGWR) 4 18457;;oracle8 ;;;;;oracle@saic02 (CKPT) 5 18459;;oracle8;;;oracle@saic02 (SMON) 6 18461;;oracle8;;;oracle@saic02 (RECO) 7 19168;;oracle8;;;sqlplus@saic02(TNS V1-V3)7 rows selected.每一個后臺進程都有一行,還有一行信息是與SQL*Plus會話相關(guān)的,SPID對應(yīng)相應(yīng)的UNIX進程號。 在WINDOWS2000上的ORACLE后臺進程回到WINDOWS上,從操作系統(tǒng)中察看后臺進程有些困難。從任務(wù)治理器中可能會看到運行著的應(yīng)用(任務(wù)治理器的察看方法:在任務(wù)欄點擊右鍵選擇'任務(wù)治理器')。在服務(wù)器上ORACLE可以是可用的,運行著的應(yīng)用卻是不可見的。進程表的確顯示一個進程叫做ORACLE.EXE,察看alert log 顯示ORACLE的所有后臺進程都是啟動的:PMON started with pid=2DBW0 started with pid=3LGWR started with pid=4CKPT started with pid=5SMON started with pid=6RECO started with pid=7要看實際的后臺進程,需要運行額外的軟件,例如,進程察看器。該軟件可以從Windows 2000 CD 中得到(Windows NT 的話可以從資源包中得到)。在Windows 2000上,ORACLE實例是作為一個單一的Windows 2000進程(ORACLE.EXE)實現(xiàn)的。這個進程包括實例所需要實現(xiàn)的每個任務(wù)的線程。 因此一個線程對應(yīng)每個ORACLE 后臺進程。ORACLE.EXE進程作為一個服務(wù)運行,可以從控制面板的服務(wù)中察看到 ORACLEServiceSID。其他的服務(wù)也可以這樣控制。這答應(yīng)ORACLE在沒有用戶登錄服務(wù)器的時候也持續(xù)的運行。對于共享主處理器資源的所有的進程來說,ORACLE能夠達到高速、低負荷的上下文切換。在Unix下顯示ORACLE中的進程,我們也可以通過輸入簡單的SQL語句來達到。為了顯示PID列,SQL語句做了些稍微的改動。要注重PID匹配警告日志中報告的值。SELECT s.sid, p.pid, p.spid signaled, s.osuser, s.program FROM v$process p, v$session s WHERE p.addr=s.paddr;SID;;;PID THREADID; OSUSER; PROGRAM---- ------- --------- --------------- -------------------- 1;;;;2 1088;;;SYSTEM; ORACLE.EXE 2;;;;3 1172;;;SYSTEM; ORACLE.EXE 3;;;;4 1180;;;SYSTEM; ORACLE.EXE 4;;;;5 1192;;;SYSTEM; ORACLE.EXE 5;;;;6 1212;;;SYSTEM; ORACLE.EXE 6;;;;7 1220;;;SYSTEM; ORACLE.EXE 7;;;;8 1200;;;AdministratorSQLPLUSW.EXE7 rows selected.每一個后臺進程都有一行,還有一行信息是與SQL*Plus會話相關(guān)。程序名字并沒有指明后臺進程的名字,和在Unix 中一樣,這些名字可以通過和v$bgprocess 連接得到。SELECT s.sid SID, p.spid THREADID, p.program PROCESSNAME, bg.name NAMEFROM v$process p, v$session s, v$bgprocess bg WHERE p.addr = s.paddr AND; p.addr = bg.paddr AND; bg.paddr <> '00' ; SID THREADID; PROCESSNAME;;NAME ---------- --------- --------------- ------------- 1 1088;;;ORACLE.EXE;;;PMON 2 1172;;;ORACLE.EXE;;;DBW0 3 1180;;;ORACLE.EXE;;;LGWR 4 1192;;;ORACLE.EXE;;;CKPT 5 1212;;;ORACLE.EXE;;;SMON 6 1220;;;ORACLE.EXE;;;RECO 6 rows selected.斷開會話提交SQL命令 ALTER SYSTEM DISCONNECT SESSION可以斷開會話。 有的時候需要在操作系統(tǒng)級別斷開會話,在UNIX上,通過kill命令實現(xiàn),前面例子中的SQL會話可以通過輸入UNIX命令斷開:kill -9 19168在Windows 2000上可以用orakill斷開一個會話。orakill是Windows平臺上的ORACLE的一個特定命令,默認安裝在$ORACLE_HOMEbin下。在命令行下輸入orakill可以察看它的用法。前面例子中的SQL*Plus會話可以通過輸入如下的命令斷開:orakill atei 1200Kill of thread id 1200 in instance atei sUCcessfully signaled.在Windows 2000中,假如一個斷開的會話標(biāo)記為 'marked for kill'但是沒被刪除,orakill會終止它。要記住殺掉一個后臺進程總不是個好主意,尤其是Windows上,會導(dǎo)致進程崩潰,甚至導(dǎo)致數(shù)據(jù)庫不可用。Windows 2000 注冊表和其他的Windows 2000中的應(yīng)用那樣,ORACLE的大多數(shù)的設(shè)定都在注冊表中。應(yīng)該看看HKEY_LOCAL_MACHINE OFTWAREORACLE下面都有什么。這些參數(shù)中的一些在后面會具體討論。和ORACLE服務(wù)相關(guān)的參數(shù)和其他的服務(wù)一樣存貯在同樣的位置: HKEY_LOCAL_MACHINE YSTEMCurrentControlSet ervices。環(huán)境變量在Unix中兩個最重要的變量是ORACLE_HOME和ORACLE_SID。一旦這些變量設(shè)定的話,應(yīng)用就可以運行并聯(lián)接到本地數(shù)據(jù)庫。 通常也把$ORACLE_HOME/bin 包含在 $PATH 中以便在使用ORACLE 工具(如:sqlplus)的時候免去輸入全路徑的麻煩。Windows 2000 中可以打開命令行設(shè)定ORACLE_SID 變量再聯(lián)接到本地數(shù)據(jù)庫。其他的值可以從注冊表中得到。MULTIPLE ORACLE HOMESWindows 2000全面支持多個ORACLE home。以前在Windows NT上這是個主要的問題,一直到ORACLE8.0.4以后才開始支持。最初得對這一點的支持很差勁。ORACLE Home Selector, ORACLE8i的一個新的應(yīng)用工具, 改變環(huán)境路徑,使選擇的ORACLE home 路徑作為主的home。只是簡單的改變系統(tǒng)路徑,把ORACLE選擇的BIN目錄放在啟動路徑中。每一個 BIN目錄都有一個ORACLE.KEY文件,指明在注冊表中ORACLE程序在哪里可以找ORACLE_HOME 和其他的環(huán)境變量。假如在服務(wù)器上面只有一個數(shù)據(jù)庫,通常在注冊表中設(shè)定ORACLE_SID。不過,不要設(shè)定 ORACLE_HOME,對于ORACLE產(chǎn)品來說根本不需要,可能會導(dǎo)致問題。文件系統(tǒng)多 ORACLE home的支持答應(yīng)在Windows上面實現(xiàn) Unix 的OFA 標(biāo)準(zhǔn)。這極大的簡化了從Unix的過渡。OFA目錄樹的頂層的名字有差異,不過主要的子目錄和文件名字在兩種操作系統(tǒng)中都是一致的。UnixNTORACLE_BASE/oracle/app/oracleD:OracleORACLE_HOME/oracle/app/oracle/product/8.1.7D:OracleOra817Admin Directories/oracle/app/oracle/adminD:OracleAdminDatabase files/db01/oradata/SIDD:OracleOradata ID/db02/oradata/SIDF:OracleOradata ID/db03/oradata/SIDG:OracleOradata ID服務(wù)治理器從ORACLE 8i開始,服務(wù)治理器的名字在不同的平臺上都一致了,都叫做svrmgrl。以前在 Windows NT上ORACLE的執(zhí)行文件名字隨著版本變動而改變,對于那些在多平臺上工作的人來說這很令人討厭,尤其是在使用一些命令(imp、eXP等)的時候。------------------------------------------------------------------ORACLE 服務(wù)器版本 Windows 服務(wù)器治理器可執(zhí)行文件------------------------------------------------------------------7.3; ; svrmgr238.0; ;;;;;svrmgr308.1; ; svrmgrl------------------------------------------------------------------要注重server manager 正在逐步被淘汰(譯者注:9i中徹底淘汰了svrmgrl),一些額外的功能被加到了SQL*Plus 中。 PartI. To Be Continued…..
標(biāo)簽: Oracle 數(shù)據(jù)庫
主站蜘蛛池模板: 五月天激激婷婷大综合蜜芽 | 成人在线综合 | 欧美一级片在线免费观看 | 日韩国产成人精品视频 | 99久久99热精品免费观看国产 | 国产高清厕所盗摄视频 | 久久精品国产国产 | 日本免费高清视频二区 | a级毛片免费全部播放 | xx毛片| 欧美一级视频精品观看 | 亚洲欧美综合国产精品一区 | 又黄又骚 | 国产三级三级三级三级 | 男人和女人在床做黄的网站 | 日韩精品欧美激情国产一区 | 91九色偷拍| 精品国产三级在线观看 | 国产超薄肉色丝袜足j | 国产欧美一区二区三区免费 | 一个人免费观看日本www视频 | 免费久草视频 | 成年人黄视频在线观看 | 一级一级 a爱片免费视频 | 91欧美在线视频 | 成人欧美日韩高清不卡 | 国产片一级片 | 亚洲美色综合天天久久综合精品 | 久久色精品 | 一道精品视频一区二区三区图片 | 欧美精品免费看 | 加勒比综合在线 | 三级视频在线播放 | 免费视频 久久久 | 日本精品夜色视频一区二区 | 久久精品在 | 国产精品不卡在线 | 国产精品亚洲欧美日韩一区在线 | 免费观看a级毛片在线播放 免费观看a级网站 | 欧美极品第1页专区 | 国产亚洲精品高清在线 |