主頁 > 知識庫 > oracle日志操作模式(歸檔模式和非歸檔模式的利與弊)

oracle日志操作模式(歸檔模式和非歸檔模式的利與弊)

熱門標簽:百度地圖標注員是干什么 北京外呼系統(tǒng)公司排名 外呼系統(tǒng)口號 外呼系統(tǒng)鄭州 北京營銷外呼系統(tǒng)廠家 溫州人工外呼系統(tǒng) 貴陽智能電銷機器人官網(wǎng) 沈陽400電話是如何辦理 地圖標注付款了怎么找不到了
筆者今天就談談自己對這兩種操作模式的理解,并且給出一些可行的建議,跟大家一起來提高Oracle數(shù)據(jù)庫的安全性。

一、非歸檔模式的利與弊。

  非歸檔模式是指不保留重做歷史的日志操作模式,只能夠用于保護例程失敗,而不能夠保護介質損壞。如果數(shù)據(jù)庫采用的是日志操作模式的話,則進行日志切換時,新的日志會直接覆蓋原有日志文件的內容,不會保留原有日志文件中的數(shù)據(jù)。
  這么說聽起來可能比較難理解。筆者舉一個簡單的例子,就會清楚許多。如現(xiàn)在Oracle數(shù)據(jù)庫中有四個日志組,日志序列號分別為11、 12、13、14。當數(shù)據(jù)庫事務變化寫滿第一個日志組文件(序列號為11)時,Oracle數(shù)據(jù)庫就會自動切換到第二個日志組文件(序列號為12)中。依次類推。當?shù)谌齻€日志組文件(序列號為13)寫滿時,就會切換到第四個日志組(序列號為14)。當?shù)谒膫€日志組(序列號為14)滿時,其就會切換到第一個日志組(序列號為15)。這里,序列號雖然與剛才第一個日志文件組不同,但是日志組仍然是同一個。此時,由于數(shù)據(jù)庫的操作模式選擇為非歸檔模式,所以第一組日志文件(序列號為11)中的內容并沒有歸檔。新的日志文件的內容將直接覆蓋第一個日志組文件中的內容。若第一個日志組文件(序列號為15)滿時,切換到第二個日志文件組時,新的內容又會在第二個日志文件組沒有歸檔的情況下,直接覆蓋日志文件12中的原有數(shù)據(jù)。

  通過以上的分析,我們可以歸納出非歸檔操作日志模式的一些特點。

  一是當檢查點完成之后,后臺進程可以覆蓋原有重做日志的內容。也就是說,在日志切換時,后來的日志文件內容可以在以前的日志文件內容沒有歸檔的情況下,覆蓋原有日志文件的內容。如此的話,當出現(xiàn)數(shù)據(jù)文件損壞時,數(shù)據(jù)庫管理員只能夠恢復到過去的完全被分點。如數(shù)據(jù)庫有四個日志組。如果在日志組序列號為16的時候數(shù)據(jù)庫管理員進行了完全備份。而在日志組序列號為28的時候數(shù)據(jù)文件出現(xiàn)了損壞。此時,由于中間的日志文件內容被覆蓋掉了。所以,此時數(shù)據(jù)庫管理員只能夠恢復到完全備份的那個點,而不能夠恢復數(shù)據(jù)庫文件損壞時的點的數(shù)據(jù)(即序列號為28)的數(shù)據(jù)。如果在序列號為18的時候出現(xiàn)了數(shù)據(jù)文件損壞的事故,則可以先對數(shù)據(jù)庫進行還原(還原點為序列號為16時的數(shù)據(jù)),然后再利用重做日志文件(序列號為17、18),即可以把數(shù)據(jù)恢復到故障發(fā)生時的數(shù)據(jù)。故雖然不用對重做日志文件進行歸檔,節(jié)省磁盤空間。但是,卻給后續(xù)數(shù)據(jù)庫的恢復帶來的麻煩,降低了數(shù)據(jù)庫的安全性。為此,如何取舍,還是需要數(shù)據(jù)庫管理員根據(jù)自己企業(yè)的情況,作出選擇。

  二是執(zhí)行數(shù)據(jù)庫備份時,必須要備份所有數(shù)據(jù)文件和控制文件。根據(jù)上面筆者所講述的,因為重做日志會被后來的所覆蓋,所以,基本上數(shù)據(jù)庫管理員不能夠通過重做日志文件來恢復數(shù)據(jù)庫的數(shù)據(jù),或者說,通過重做日志文件不能夠恢復全部的數(shù)據(jù)。為此,在執(zhí)行數(shù)據(jù)庫備份時,就必須備份所有的數(shù)據(jù)文件和控制文件。同時,還必須使用SHUTDOWNNORMAL等命令關閉數(shù)據(jù)庫。
  
二、歸檔日志模式。


  歸檔日志模式與非歸檔日志模式相對應,是指保留重做日志歷史的日志操作模式。這種日志操作模式不僅可用于保護例程失敗,還可以用于保護介質損壞的情況。如果數(shù)據(jù)庫管理員把日志設置為歸檔日志模式,則當后臺進程在進行日志切換時,后臺進程會自動將重做日志的內容復制到歸檔日志中。歸檔日志就是非活動重做日志的備份。

  如現(xiàn)在Oracle數(shù)據(jù)庫中有四個日志組,日志序列號分別為11、12、13、14。當數(shù)據(jù)庫事務變化寫滿第一個日志組文件(序列號為11) 時,后臺進程就會切換到第二個日志組中(序列號為12)。不過在這個切換之前,數(shù)據(jù)庫有一個進程,會負責將第一個日志組中的文件內容復制到歸檔日志中去。依次類推。這就是歸檔日志模式與非歸檔日志模式最本質的區(qū)別。不過這個區(qū)別卻給數(shù)據(jù)庫安全性帶來了很大的變化。

  如當日志序列號為28時出現(xiàn)了數(shù)據(jù)文件的錯誤或者服務器硬盤損壞的事故時,因為日志文件中記錄了從數(shù)據(jù)庫備份以來所有的數(shù)據(jù)變化情況。而且這些日志文件與數(shù)據(jù)庫備份文件存儲在其他媒體中,那么數(shù)據(jù)庫管理員就可以通過這些資料,把數(shù)據(jù)庫恢復到介質損壞時(即日志文件序列號為28)的數(shù)據(jù)。從保護數(shù)據(jù)庫數(shù)據(jù)的角度講,這是一個接近于比較理想的狀態(tài)了。

  若把非歸檔模式與歸檔模式進行對比的話,可以發(fā)現(xiàn)歸檔模式有如下的特點。
一是當出現(xiàn)介質損壞(如硬盤損壞或者意外刪除數(shù)據(jù)文件)或者出現(xiàn)例程失敗(如服務器突然斷電)時,數(shù)據(jù)庫管理員可以憑借歸檔日志文件來防止丟失數(shù)據(jù)。而非歸檔模式則往往只能夠應對例程失敗的情況。所以,其應用范圍要比非歸檔模式大的多。

  二是數(shù)據(jù)備份的限制條件。正如上面所說的,如果數(shù)據(jù)庫處于非歸檔模式,則對數(shù)據(jù)庫進行備份時,要先用SHUTDOWNNORMAL等命令關閉數(shù)據(jù)庫。而處于歸檔模式的時候,則當數(shù)據(jù)庫處于Open狀態(tài)時,數(shù)據(jù)庫管理員仍然可以備份數(shù)據(jù)庫,而且不會影響數(shù)據(jù)庫的正常使用。除了數(shù)據(jù)庫備份兩者有本質上的差異之外,在數(shù)據(jù)庫恢復上也有很大的差別。若數(shù)據(jù)庫采用歸檔日志模式,不僅可以執(zhí)行完全恢復,而且在歸檔日志文件的幫助下,還可以將數(shù)據(jù)庫恢復到特定的點。從而當數(shù)據(jù)庫出現(xiàn)意外故障時,最大限度的保護數(shù)據(jù)的安全性。
  不過若采取歸檔模式的話,則必須要犧牲一定的磁盤空間。

三、如何選擇合適的日志操作模式?

  非歸檔模式只適用于例程失敗時恢復數(shù)據(jù),不能夠用來保護介質損壞。即當數(shù)據(jù)庫的數(shù)據(jù)文件意外損壞時,非歸檔模式?jīng)]有應對之策。歸檔模式不僅可以用來保護例程失敗,而且還可以在介質失敗的時候,最大程度的恢復數(shù)據(jù)庫的原有數(shù)據(jù)。此時,數(shù)據(jù)庫管理員可以利用數(shù)據(jù)庫備份文件、歸檔日志文件、重做日志文件等把數(shù)據(jù)庫中的數(shù)據(jù)恢復到故障發(fā)生的那一時點。

  既然歸檔操作模式與非歸檔操作模式各有各的特點,那么在什么時候采用歸檔日志模式為好,什么時候又該采用非歸檔模式呢?這個問題的答案,是公說公有理,婆說婆有理??峙聽幷搨€幾年也沒有一個固定的答案。對此,筆者就提一下自己的意見。這也不是標準答案,只是供大家參考。

  首先要看數(shù)據(jù)庫中數(shù)據(jù)變化的頻繁程度。當數(shù)據(jù)庫中數(shù)據(jù)變化比較少的時候,則最好采用非歸檔模式。相反,如果數(shù)據(jù)庫中的數(shù)據(jù)變化比較頻繁,如一些業(yè)務操作系統(tǒng),則最好能夠采用歸檔模式。

  其次,要看企業(yè)對數(shù)據(jù)丟失的態(tài)度。如果企業(yè)對于數(shù)據(jù)安全要求比較高,如銀行,不允許丟失任何數(shù)據(jù),則最好能夠采用歸檔日志模式。在數(shù)據(jù)庫意外故障的時候,其可以幫助數(shù)據(jù)庫管理員在最大程度上恢復數(shù)據(jù)。同理,當企業(yè)可以允許部分損壞數(shù)據(jù)的時候,則可以采用非歸檔模式,以節(jié)省切換日志組時的對日志文件備份的額外開銷與磁盤空間。

  再者,要看看數(shù)據(jù)庫是否需要全天候運行。因為在非歸檔模式下,必須利用SHUTDOWNNORMAL等命令關閉數(shù)據(jù)庫,才能過對數(shù)據(jù)庫進行備份。這跟數(shù)據(jù)庫全天候運行的要求是不符合的。而歸檔模式下,即使數(shù)據(jù)庫出于OPEN狀態(tài),也可以對其進行備份,也不會影響數(shù)據(jù)庫的正常運行。為此,若果數(shù)據(jù)庫需要全天候運行的話,則最好采用歸檔模式。雖然數(shù)據(jù)庫為此要付出一些額外的開銷,筆者認為也是值得的。畢竟硬件投資有價,數(shù)據(jù)無價。

  數(shù)據(jù)庫管理員要根據(jù)企業(yè)的實際情況,選擇合適的日志操作模式。從而讓重做日志與歸檔日志真正成為Oracle數(shù)據(jù)庫的保護傘。
您可能感興趣的文章:
  • Oracle切換為歸檔模式的步驟及問題解決
  • oracle的歸檔模式 ORACLE數(shù)據(jù)庫歸檔日志常用命令
  • 數(shù)據(jù)庫ORA-01196故障-歸檔日志丟失恢復詳解

標簽:衢州 淮北 溫州 衡水 潮州 包頭 定西 通遼

巨人網(wǎng)絡通訊聲明:本文標題《oracle日志操作模式(歸檔模式和非歸檔模式的利與弊)》,本文關鍵詞  oracle,日志,操作,模式,歸檔,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《oracle日志操作模式(歸檔模式和非歸檔模式的利與弊)》相關的同類信息!
  • 本頁收集關于oracle日志操作模式(歸檔模式和非歸檔模式的利與弊)的相關信息資訊供網(wǎng)民參考!
  • 推薦文章