亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

UNIX 和 WINDOWS2000 上的 ORACLE 的差異

2024-08-29 13:49:24
字體:
來源:轉載
供稿:網友

  
 

 

Ian Adam,          SAIC Ltd

David Stien,       SAIC Ltd

翻譯:Fenng       

 

摘要

Oracle是廣為人知的Unix硬件平臺上的領先的數據庫系統。ORACLE用戶和治理員因此熟悉Unix平臺上的ORACLE架構以及它上面的工具和技巧,并從他們的數據庫得到最大的收益。相反,Windows上的ORACLE架構就不那么的被廣為了解。這篇文章從一個DBA的角度考察了兩個操作系統之間的要害的異同點。

 

簡介

在看了幾本令人失望的這方面的書之后,我們寫了這篇文章。那些書的通病是試圖做太多的事情--在細節上講述Windows和ORACLE。我們的這篇文章假定讀者熟悉Unix平臺上的ORACLE DBA的工作。因此本文將分析兩個平臺上的ORACLE的要害的差異而不是從頭教你ORACLE的技巧。我們不想把它作為你的一份詳盡的指導或者是手冊的替代品,事實上它可能鼓勵你閱讀一些手冊。作為數據庫服務器平臺,它只會涉及一些Unix和Windows上相關的優點,這就是本文的目的。

 

范例

這個例子使用linux上的ORACLE 8i,實例名字叫作eighti。windows 2000上面的ORACLE 8i的實例名字叫作atei。

 

客戶端對ORACLE的訪問

當客戶端連接到ORACLE時,通常的來說ORACLE服務器的平臺與客戶端的應用無關。這實際上很難說清。 ORACLE DBA 和系統治理人員更關心操作系統平臺,他們有的時候會基于需求(如運行時間和可擴展性)選擇平臺。 更通常的情況下,他們接受(或是接手)給定的平臺并學習從中得到最大受益。

 

關于WINDOWS 2000

值得一提的是Windows 2000是從Windows NT升級而來。在這兩個操作系統之間有很多的相似點,Windows 2000 也有些新的特性。微軟從NT4.0的升級途徑見下表。

 

兩個系統間有很多相似點:

-------------------------------------------------------------------------------------

NT 4.0                                                     Windows 2000

-------------------------------------------------------------------------------------

NT 4.0 Workstation                                  Windows 2000 PRofessional

NT 4.0 Server                                         Windows 2000 Server

NT 4.0 Enterprise Edition                        Windows 2000 Advanced server

Unix                                                         Windows 2000 Datacenter server

-------------------------------------------------------------------------------------

 

 

ORACLE后臺進程

下面這句話對于用過ORACLE的人來說是會很熟悉的:"每一個運行著的ORACLE數據庫都對應一個ORACLE實例,當一個數據庫在數據庫服務器(不考慮機器的類型)上啟動的時候,ORACLE分配一塊叫做System Global Area (SGA)的內存區域并啟動一個或者多個ORACLE進程。
SGA和ORACLE進程合起來稱作ORACLE 實例。"――摘自 ORACLE 8i Concepts [4 L Leverenz, 1999]。處理后臺進程是放在首位的,也是不同的操作系統之間最明顯的差異。

 

ORACLE在UNIX上的后臺進程

任何連接到UNIX的用戶都可以很輕易的察看ORACLE的后臺進程:

 

% ps -efgrep eightigrep -v grep

 

oracle8 18451     1  0 16:37:18 ?        0:00 ora_pmon_eighti

oracle8 18453     1  0 16:37:19 ?        0:00 ora_dbw0_eighti

oracle8 18457     1  0 16:37:19 ?        0:04 ora_ckpt_eighti

oracle8 18461     1  0 16:37:19 ?        0:00 ora_reco_eighti

oracle8 18455     1  0 16:37:19 ?        0:02 ora_lgwr_eighti

oracle8 18459     1  0 16:37:19 ?        0:01 ora_smon_eighti

oracle8 19168 19167  0 16:43:46 ?        0:00 oracleeighti

                           (DESCRipTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))

 

最后一行的ORACLE進程與一個SQL*Plus會話相關,其他的進程都是后臺進程。在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會話相關的,SPID對應相應的UNIX進程號。


 

 

在WINDOWS2000上的ORACLE后臺進程

回到WINDOWS上,從操作系統中察看后臺進程有些困難。從任務治理器中可能會看到運行著的應用(任務治理器的察看方法:在任務欄點擊右鍵選擇"任務治理器")。在服務器上ORAC

LE可以是可用的,運行著的應用卻是不可見的。進程表的確顯示一個進程叫做ORACLE.EXE,

察看alert log 顯示ORACLE的所有后臺進程都是啟動的:

 

PMON started with pid=2

DBW0 started with pid=3

LGWR started with pid=4

CKPT started with pid=5

SMON started with pid=6

RECO started with pid=7

 

要看實際的后臺進程,需要運行額外的軟件,例如,進程察看器。該軟件可以從Windows

2000 CD 中得到(Windows NT 的話可以從資源包中得到)。

 

在Windows 2000上,ORACLE實例是作為一個單一的Windows 2000進程(ORACLE.EXE)實現的。這個進程包括實例所需要實現的每個任務的線程。

因此一個線程對應每個ORACLE 后臺進程。ORACLE.EXE進程作為一個服務運行,可以從控制面板的服務中察看到 ORACLEServiceSID。其他的服務也可以這樣控制。

 

這答應ORACLE在沒有用戶登錄服務器的時候也持續的運行。對于共享主處理器資源的所有的進程來說,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      Administrator   SQLPLUSW.EXE

7 rows selected.

 

每一個后臺進程都有一行,還有一行信息是與SQL*Plus會話相關。程序名字并沒有指明后臺進程的名字,和在Unix 中一樣,這些名字可以通過和v$bgprocess 連接得到。

 

SELECT s.sid SID, p.spid THREADID, p.program PROCESSNAME, bg.name NAME

FROM 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可以斷開會話。
有的時候需要在操作系統級別斷開會話,在UNIX上,通過kill命令實現,前面例子中的SQL會話可以通過輸入UNIX命令斷開:

 

kill -9 19168

 

在Windows 2000上可以用orakill斷開一個會話。orakill是Windows平臺上的ORACLE的一個特定命令,默認安裝在$ORACLE_HOME/bin下。在命令行下輸入orakill可以察看它的用法。前面例子中的SQL*Plus會話可以通過輸入如下的命令斷開:

 

orakill atei 1200

Kill of thread id 1200 in instance atei sUCcessfully signaled.

 

在Windows 2000中,假如一個斷開的會話標記為 "marked for kill"但是沒被刪除,orakill會終止它。要記住殺掉一個后臺進程總不是個好主意,尤其是Windows上,會導致進程崩潰,甚至導致數據庫不可用。

 

Windows 2000 注冊表

和其他的Windows 2000中的應用那樣,ORACLE的大多數的設定都在注冊表中。應該看看HKEY_LOCAL_MACHINE OFTWARE/ORACLE下面都有什么。這些參數中的一些在后面會具體討論。和ORACLE服務相關的參數和其他的服務一樣存貯在同樣的位置:

HKEY_LOCAL_MACHINE YSTEM/CurrentControlSet ervices。

 

 

環境變量

在Unix中兩個最重要的變量是ORACLE_HOME和ORACLE_SID。一旦這些變量設定的話,應用就可以運行并聯接到本地數據庫。 通常也把$ORACLE_HOME/bin 包含在 $PATH

中以便在使用ORACLE 工具(如:sqlplus)的時候免去輸入全路徑的麻煩。

 

Windows 2000 中可以打開命令行設定ORACLE_SID 變量再聯接到本地數據庫。其他的值可以從注冊表中得到。

 

MULTIPLE ORACLE HOMES

Windows 2000全面支持多個ORACLE home。以前在Windows NT上這是個主要的問題,一直到ORACLE8.0.4以后才開始支持。最初得對這一點的支持很差勁。ORACLE Home Selector, ORACLE8i的一個新的應用工具, 改變環境路徑,使選擇的ORACLE home 路徑作為主的home。只是簡單的改變系統路徑,把ORACLE選擇的BIN目錄放在啟動路徑中。

 

每一個 BIN目錄都有一個ORACLE.KEY文件,指明在注冊表中ORACLE程序在哪里可以找ORACLE_HOME 和其他的環境變量。假如在服務器上面只有一個數據庫,通常在注冊表中設定ORACLE_SID。不過,不要設定 ORACLE_HOME,對于ORACLE產品來說根本不需要,可能會導致問題。

 

文件系統

多 ORACLE home的支持答應在Windows上面實現 Unix 的OFA 標準。這極大的簡化了從Unix的過渡。OFA目錄樹的頂層的名字有差異,不過主要的子目錄和文件名字在兩種操作系統中都是一致的。

 

 

Unix

NT

ORACLE_BASE

/oracle/app/oracle

D:/Oracle

ORACLE_HOME

/oracle/app/oracle/product/8.1.7

D:/Oracle/Ora817

Admin Directories

/oracle/app/oracle/admin

D:/Oracle/Admin

Database files

/db01/oradata/SID

D:/Oracle/Oradata ID

 

/db02/oradata/SID

F:/Oracle/Oradata ID

 

/db03/oradata/SID

G:/Oracle/Oradata ID

 

 

服務治理器

從ORACLE 8i開始,服務治理器的名字在不同的平臺上都一致了,都叫做svrmgrl。以前在

Windows NT上ORACLE的執行文件名字隨著版本變動而改變,對于那些在多平臺上工作的人來說這很令人討厭,尤其是在使用一些命令(imp、eXP等)的時候。

 

------------------------------------------------------------------

ORACLE 服務器版本          Windows 服務器治理器可執行文件

------------------------------------------------------------------

 7.3                             svrmgr23

 8.0                             svrmgr30

 8.1                             svrmgrl

------------------------------------------------------------------

 

要注重server manager 正在逐步被淘汰(譯者注:9i中徹底淘汰了svrmgrl),一些額外的功能被加到了SQL*Plus 中。


 

PartI. To Be Continued…..

 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
主播福利视频一区| 国产亚洲精品久久久久久牛牛| 日本韩国欧美精品大片卡二| 在线免费观看羞羞视频一区二区| 久久久久久亚洲精品不卡| 成人欧美一区二区三区黑人孕妇| 欧美激情在线一区| 久久久久久久久国产精品| 欧美高清无遮挡| 国产日韩中文字幕| 久久人人爽人人爽爽久久| 久久久久久久av| 亚洲精品自拍视频| 欧美夫妻性生活视频| 欧美另类高清videos| 亚洲第一区中文99精品| 欧美日韩亚洲视频一区| 成人精品一区二区三区| 国产午夜精品全部视频播放| 国产精品视频导航| 日韩中文av在线| www.午夜精品| 亚洲国产小视频在线观看| 欧美亚洲国产视频| 亚洲午夜性刺激影院| 国产一区二区三区直播精品电影| 欧美综合在线第二页| 亚洲综合在线小说| 久久久精品免费视频| 日韩精品视频中文在线观看| 懂色av中文一区二区三区天美| 亚洲成人亚洲激情| 精品久久久久久国产| 欧美日韩国产中文字幕| 亚洲老板91色精品久久| 欧美极品欧美精品欧美视频| 国产精品美女主播在线观看纯欲| 久久久久九九九九| 欧美日韩激情美女| 欧美大片在线看免费观看| 亚洲人成伊人成综合网久久久| 亚洲精品一区二区久| 久久综合久中文字幕青草| 久久中文字幕国产| 九九热精品在线| 亚洲欧洲午夜一线一品| 超碰日本道色综合久久综合| 欧美在线观看日本一区| 亚洲国产精品va| 国产精品www网站| 日本国产欧美一区二区三区| 欧美国产在线电影| 91精品国产色综合久久不卡98口| 欧美极度另类性三渗透| 亚洲天堂影视av| 91av在线精品| 国产精品88a∨| 日韩中文字幕在线| 中文字幕日韩欧美| 蜜臀久久99精品久久久久久宅男| 国产精品成人一区二区| 日韩人体视频一二区| 人体精品一二三区| 欧美大码xxxx| 日韩视频免费观看| 成人国内精品久久久久一区| 亚洲一区二区三区成人在线视频精品| 欧美激情精品久久久久久| 中文字幕自拍vr一区二区三区| 一区二区三区久久精品| 精品av在线播放| 国内精久久久久久久久久人| 中文字幕欧美专区| 国产ts人妖一区二区三区| 久久久精品一区二区| 欧美一区二区三区四区在线| 国产盗摄xxxx视频xxx69| 日韩毛片在线看| 欧美午夜片在线免费观看| 亚洲精品视频在线观看视频| 国产日韩精品一区二区| 欧美日韩xxxxx| 成人av资源在线播放| 精品视频在线播放免| 日韩成人在线观看| 日韩av在线电影网| 日韩高清中文字幕| 黑人狂躁日本妞一区二区三区| 97国产成人精品视频| www.欧美三级电影.com| 亚洲电影在线看| 91网站免费观看| 国自产精品手机在线观看视频| 久久久人成影片一区二区三区| 国产日韩欧美综合| 91欧美精品成人综合在线观看| 美女撒尿一区二区三区| 在线亚洲欧美视频| 日韩美女视频中文字幕| 久久影视电视剧免费网站| 97人人模人人爽人人喊中文字| 中文字幕亚洲字幕| 国产精品久久久久久一区二区| 色婷婷亚洲mv天堂mv在影片| 91视频国产一区| 久久综合免费视频| 中文在线资源观看视频网站免费不卡| 久久99久久99精品免观看粉嫩| 亚洲精品国产综合区久久久久久久| 欧美寡妇偷汉性猛交| 国产乱人伦真实精品视频| 国产在线观看不卡| 国产丝袜精品第一页| 欧美亚洲国产成人精品| 日韩欧美精品中文字幕| 亚洲最大福利视频网站| 国产主播喷水一区二区| 日韩欧美成人区| 亚洲第一中文字幕在线观看| 成人亲热视频网站| 久久亚洲精品视频| 欧美激情极品视频| 91色视频在线导航| 北条麻妃一区二区在线观看| 成人乱人伦精品视频在线观看| 国产盗摄xxxx视频xxx69| 国产精品视频在线播放| 欧美激情aaaa| 日韩精品高清在线观看| 91亚洲永久免费精品| 最近中文字幕mv在线一区二区三区四区| 欧美性做爰毛片| 久久精品视频在线观看| 欧美美女18p| 欧美中文在线视频| 日韩女优在线播放| 综合网日日天干夜夜久久| 国语自产在线不卡| 亚洲a区在线视频| 亚洲999一在线观看www| 91精品久久久久久久久久| 色婷婷综合成人| 国产成人福利夜色影视| 成人免费xxxxx在线观看| 成人乱人伦精品视频在线观看| 久久久久久亚洲精品不卡| 亚洲国产欧美一区| 色妞一区二区三区| 精品日本高清在线播放| 精品国偷自产在线| 色偷偷亚洲男人天堂| 欧美肥老太性生活视频| 日韩在线观看免费全| 91亚洲精品久久久| 国产精品99导航| 亚洲国产天堂久久综合网| 精品国模在线视频| 色婷婷av一区二区三区在线观看| 国产精品吹潮在线观看| 欧美在线精品免播放器视频| 亚洲美女av在线| 亚洲色图综合网| 亚洲香蕉伊综合在人在线视看| 欧美性视频在线|