亚洲天堂一级片-亚洲天堂三区-亚洲天堂久久精品成人-亚洲天堂毛片-久久国产欧美日韩高清专区-久久国产欧美日韩精品免费

Oracle數(shù)據(jù)庫與SQL Server數(shù)據(jù)庫鏡像對比

    數(shù)據(jù)庫鏡像是將數(shù)據(jù)庫事務處理從一個數(shù)據(jù)庫移動到不同環(huán)境中的另一個數(shù)據(jù)庫中。鏡像的拷貝是一個備用的拷貝,不能直接訪問,它只用在錯誤恢復的情況下。Oracle數(shù)據(jù)庫與MSSQL數(shù)據(jù)操作上有很大的不同,但是,在鏡像操作方面有類比的地方。這篇文章關于MSSQL數(shù)據(jù)庫鏡像在Oracle數(shù)據(jù)庫中是如何實現(xiàn)的,它們之間存在哪些差異呢。

    首先,微軟SQL數(shù)據(jù)庫中的鏡像數(shù)據(jù)庫類似于Oracle數(shù)據(jù)庫中的備用數(shù)據(jù)庫。我說的只是類似,確切的說,我們需要考慮不同數(shù)據(jù)庫在自己體系中的差異。MSSQL作為一個實例來操作,一個實例包含幾個數(shù)據(jù)庫,你首先要登錄一個實例,然后選擇哪個數(shù)據(jù)庫作用于該實例。而在Oracle數(shù)據(jù)庫中,簡單模式(忽略RAC)就只有一個數(shù)據(jù)庫與一個實例相聯(lián)系。因此,可以這么說,在Oracle數(shù)據(jù)庫中,備份數(shù)據(jù)庫(standby database)就完全是主數(shù)據(jù)庫的快照。而在MSSQL中,鏡像數(shù)據(jù)庫僅僅是選擇的那個數(shù)據(jù)庫的備份,但沒有包括代理,登錄,任務(這些或者更多的數(shù)據(jù)庫項目需要單獨在數(shù)據(jù)庫鏡像上創(chuàng)建或者復制)這些外部數(shù)據(jù)項。

    在服務器數(shù)量上,Oracle的主數(shù)據(jù)庫和備用數(shù)據(jù)庫配置最小需要2臺。在MSSQL中,最小數(shù)據(jù)是2個或3個,根據(jù)你所選擇的高可用性、高安全性、高性能方式所決定。

    高可用性方式:這個操作模式選項允許你在兩臺服務器上同步事務寫入,并支持自動錯誤恢復。要使用這個選項,你必須還要使用一個證人服務器。

    高保護方式:這個選項可以讓你在兩臺服務器上同步事物寫入,但是錯誤恢復是手工的。因為自動的錯誤恢復不是這個選項的一部分,所以也不會用到證人服務器。

    高性能方式:這個選項不關心兩臺服務器上的寫入是否是同步的,因此在性能上有所提高。當使用這個選項的時候,你只能假設鏡像服務器上的所有事情都是成功完成。這個選項只允許手工的錯誤恢復,因此不會用到證人服務器。

    為了保證故障自動恢復,就需要有第三臺服務器,可以稱之為目擊者(另外兩個就是主數(shù)據(jù)庫和鏡像數(shù)據(jù)庫),你可以將這個目擊者當作群集中的一個成員。它實現(xiàn)了2比1投票的能力,當我的一個組件不可達,并因此需要進行錯誤恢復的時候。證人服務器只有在你想實現(xiàn)自動錯誤恢復的時候才需要用到。

    在Oracle數(shù)據(jù)的一個事務中,日志緩沖器在廢數(shù)據(jù)寫入數(shù)據(jù)文件(忽略write-ahead情況)前被刷新或者寫入到redo日志中。這種刷新或者寫入到redo日志的行為是有必要的,如像實例失敗(使用前滾和回滾恢復過程)這樣的事件發(fā)生時。MSSQL也承認將日志緩沖器寫入到磁盤的重要性。不過這里稱之為硬化(hardening)。首先將事務日志緩沖器的信息寫入到磁盤或者硬化,接著將日志記錄塊發(fā)送到鏡像數(shù)據(jù)庫中。鏡像數(shù)據(jù)庫接收到該日志記錄塊后,將之存入到某個緩沖器中,隨后依次硬化該日志記錄塊。

    當數(shù)據(jù)發(fā)生變化時,MSSQL數(shù)據(jù)庫如何保持主數(shù)據(jù)庫和鏡像數(shù)據(jù)庫的一致性呢?

    Oracle用戶非常熟悉SCN,而MSSQL用戶通過使用mirroring_failover_lsn機制(粗略來講就是一個日志序列號)。MSSQL與Oracle不同,MSSQL將事務分離(兩個事務在兩個機器上),而不是一個分布式事務(在自身提交前需要遠程等待提交)。

    另外一個相似點,但稍微有些畸變的反射就是redo日志和事務日志。在Oracle中,完成的redo日志將被發(fā)送到遠程的服務器中,將完成的redo日志應用到備份數(shù)據(jù)中去。在MSSQL中,事務日志沒有被傳輸,但是就像我以上提到的,日志緩沖器數(shù)據(jù)發(fā)送到網(wǎng)絡上。這就導致另外一個鏡像反射:備份和恢復模式。

    在Oracle中,當你處于歸檔模式或者非歸檔模式的時候,這些操作是內(nèi)定的。如果歸檔redo日志被傳輸或者提交到一個遠程的服務器,那么主數(shù)據(jù)庫明顯就是在歸檔模式下,那些文件就是這么產(chǎn)生的。運行在這種模式下,允許有少量的數(shù)據(jù)丟失,因為在發(fā)生故障(無論什么樣的故障)前,恢復能夠在任意一個點上執(zhí)行。在MSSQL中是類似的,但是有三種狀態(tài)需要選擇。

    《SQL Server聯(lián)機叢書》,像許多其它的在線資源一樣,講述了在使用MSSQL時,3種恢復模式的不同點。快速的比較有:MSSQL完整模式對應于Oracle中的歸檔模式;簡單模式對應于非歸檔模式;bulk模式與使用直接路徑插入,添加提示,或者與nologging模式操作類似。

    根據(jù)以上三種模式(這三種模式很容易轉換,不需要關機或者重啟)的描述以及日志緩沖器和歸檔redo日志的討論中,很容易斷定在MSSQL中進行數(shù)據(jù)庫的鏡像需要將數(shù)據(jù)的回復模式設置成完全模式(full model)。簡單模式(Simple model)或許也能行,但是這種模式下維持事務日志中的小部分數(shù)據(jù),在備份中,如果在日志被刪節(jié)了,整個鏡像過程也就破環(huán)了,因為當你在將事務發(fā)送到鏡像數(shù)據(jù)庫中的時候,如果日志被刪節(jié)了,這個過程就不能完成。

    說到數(shù)據(jù)庫被破壞該怎么辦呢?

    這正是鏡像(或者說備份)的主要目的:當主數(shù)據(jù)庫斷開或者說遇到故障時候我們希望系統(tǒng)能回到鏡像前或者備份前的狀況去。這如何才能實現(xiàn)呢?我們能自動實現(xiàn)或者手動實現(xiàn)。想實現(xiàn)這些,需要一些已經(jīng)完成的設置。在MSSQL中,自動故障恢復,回到原來狀態(tài)需要在HA模式,事務安全是full,數(shù)據(jù)傳輸是同步,有目擊服務器的情況下。這種模式下運行還需要使用企業(yè)版的數(shù)據(jù)庫系統(tǒng)。高安全性和高性能在標準版的情況下也能實現(xiàn)。

    MSSQL還有其它版本的選擇,但是這些并不如Oracle的反射“干凈”,這些版本包括:Developer、Workgroup 和 SQL Express。舉個例子,目擊服務器能夠是任何的版本,但是如果你想給鏡像服務器做一個快照,那么你就需要企業(yè)或者開發(fā)版的了。

    在設置伙伴(partner,通常有主數(shù)據(jù)庫和鏡像數(shù)據(jù)庫組成)過程中,他們的恢復狀態(tài)開始起作用。通過使用相同的名字,鏡像在遠程/鏡像服務器上建立(使用配置數(shù)據(jù)庫鏡像安全向?qū)亲詈唵蔚姆椒?起來,并且鏡像數(shù)據(jù)庫被設置成NORECOVERY,通常它是恢復(recovering)狀態(tài)的。在MSSQL中,恢復數(shù)據(jù)庫是沒有的,因此沒有進行上述的設置,是不能被其他用戶當作只讀數(shù)據(jù)庫來使用的。

    為了避免這個中缺陷,你可以給鏡像做一個快照,使得該“影像”對用戶可見。正如我上述所提到的那樣,這需要你的數(shù)據(jù)庫版本是企業(yè)(或者開發(fā))版。這就意味著用戶需要有快照數(shù)據(jù)庫的知識,知道如何進入存儲它,如何告訴應用程序使用哪個數(shù)據(jù)庫。慣例上來說,配置文件使用的.NET環(huán)境,你

    能建立一個主數(shù)據(jù)庫和一個故障回滾的輔數(shù)據(jù)庫。如果在Oracle中配置過備份數(shù)據(jù)庫,你就會覺得這很類似。

結論

    這篇文章內(nèi)容包括按照Oracle的方式,如何更好的理解在另一種主流的RDBMS上執(zhí)行鏡像或者復制,。試著學習和解釋你的RDBMS如何工作的,從另外一種模式來得到你的注意有助于你搞清楚你當前數(shù)據(jù)庫系統(tǒng)運行原理。舉個例子,我發(fā)現(xiàn)非常有實用價值的是Oracle歸檔模式和MSSQL三種恢復模式之間的關系。使用在MSSQL中的一些術語(伙伴,主數(shù)據(jù)庫,目擊,鏡像)有助于你構成和識別Oracle中執(zhí)行數(shù)據(jù)庫鏡像的操作。

    為了更好的評價數(shù)據(jù)庫鏡像是如何運作,如何實施的,你可以運行兩個單獨的MSSQL實例,操作系統(tǒng)是XP或者是2003都沒有關系。按照MSDN聯(lián)機叢書的步驟完成一遍。下載或者選用AdventureWorks數(shù)據(jù)庫(類似于Oracle的HR/SH數(shù)據(jù)庫等。這些都沒有預安裝的),將其鏡像到主機服務器上。呈現(xiàn)在你面前的不僅僅是另外一個數(shù)據(jù)的所具有功能特性,你將還會看到MSSQL所具有的操作,得到自己的正確評價(我平時使用的是Oracle數(shù)據(jù)庫,測試用的是MSSQL,反過來說,你平時使用的是MSSQL,現(xiàn)在用Oracle來測試的話,也會有新的發(fā)現(xiàn))。

 

北大青鳥網(wǎng)上報名
北大青鳥招生簡章
主站蜘蛛池模板: 久草久草 | 久久久在线 | 免费的成人a视频在线观看 免费的毛片 | 高清午夜看片a福利在线观看琪琪 | 国产成人3p视频免费观看 | 一级做a| 性高湖久久久久久久久 | 欧美大片在线观看成人 | 亚洲国产日韩精品 | 亚洲天堂国产 | 成 人 在 线 免费 8888 www | 99色播| 农村寡妇一级毛片免费播放 | 一级特级aaa毛片 | 91久久国产露脸精品 | 亚洲综合国产一区二区三区 | 2019天天操天天干天天透 | 国产亚洲高清视频 | 久久一区视频 | 国产精品一区在线观看 | 精品热99 | 伊人久久大香线焦综合四虎 | 久久综合亚洲一区二区三区 | 2022国产91精品久久久久久 | 国产色视频一区二区三区 | 日韩经典视频 | 草草影院永久在线观看 | 中国国产一级毛片视频 | 国产日韩欧美一区二区三区在线 | 亚洲精品国产成人99久久 | 成人免费在线 | 手机看片免费基地你懂的 | 99毛片 | 国产精品久久视频 | 国产精品久久久久久久久久久久久久 | 国内精品国语自产拍在线观看55 | 欧美成人手机在线 | 亚洲夜 | 亚洲欧洲小视频 | 步兵社区在线观看 | 国产一区二区三区在线观看免费 |