最佳化Oracle停機時間及資料庫恢複

來源:互聯網
上載者:User

正在看的ORACLE教程是:最佳化Oracle停機時間及資料庫恢複。

 這裡會討論令Oracle停機時間最小化的步驟。各種形式的停機--計劃的或者是非計劃的--總是不斷地發生,一個DBA應該有正確的備份策略,這樣在資料庫出現問題時就可以更快地恢複。

  以下是假定的備份策略和資料庫的運作條件

   控制檔案是鏡像的

   資料庫運行在archivelog模式

   每個星期都進行冷備份

   每日都進行熱備份

   每日都進行一次全資料庫匯出

  事件1:完整的資料庫重構

  在這種情形下,你可以使用全資料庫匯出或者冷熱備份結合的方式來重構資料庫。要注意的是無論你選擇哪種方式,線上redo log中的事務都會丟失。

  事件2:恢複部分的資料表空間

  可以使用以下的步驟來恢複:

   1、以restrict模式啟動資料庫

   2、重新建立資料表空間

   3、使用最新的全資料庫匯出來匯入,並且使用ignore=y的選項;

   4.關閉並且重新以normal的模式啟動資料庫執行個體

  事件3:丟失一般的資料檔案

  丟失一般資料檔案的恢複步驟根據所丟失的資料檔案包含的資料表空間類型而定;例如:復原段,使用者資料表空間,索引資料表空間或者是唯讀資料表空間、你可能會遇到以下的錯誤:

   . 嘗試啟動資料庫並且碰到錯誤的資訊ORA-1157, ORA-1110,可能還有一個作業系統的錯誤

   . 嘗試以normal或者immediate的模式關閉資料庫,可能會碰到ORA-1116, ORA-1110的錯誤資訊,還有一個系統錯誤

  以下的步驟可以用作恢複:

   1、關閉資料庫

   2、由熱備份中恢複丟失的資料檔案

   3、Startup mount資料庫

   4、執行以下的查詢來得到所有你的線上redo log檔案和它們相應的次序和首次修改號:

  5、如果得到的CHANGE#比線上redo log最小的FIRST_CHANGE# 還小,那麼該檔案不能被完全恢複,你可以有兩個選擇:

   . 如果可以接受丟失最近一次冷備份以來的資料庫修改,裝入備份並且繼續恢複

   . 如果不能接受遺失資料庫的修改,那麼必須重新建立資料表空間

  6、通過使用存檔和線上的redo log來恢複資料檔案

  7、開啟資料庫

[NextPage]

事件4:恢複一個特別的表

  可以採用以下的步驟恢複:

   1、使用最近的一次全資料庫匯出來匯入表,並且使用owner=和tables=的選項

   2、考慮到效能的原因,可能需要重建表索引

  事件5:丟失控制檔案

  在資料庫起來並且運行時,通常都不能檢測到控制檔案的問題、如果控制檔案丟失或者損壞了,Oracle將不會瞭解,下次資料庫的啟動時將會導致ORA-205錯誤(標識控制檔案"%s的錯誤),還有一個系統級的錯誤、

  如果只是丟失了其中的一個控制檔案,可以採用下面的步驟來恢複:

   1、如果它正在啟動並執行話,先關閉它

   2、尋找丟失控制檔案的原因、是由於硬體的問題嗎(磁碟還是控制器)?

   3、如果不是硬體的問題,將控制檔案的一個好的拷貝複製到丟失的位置,並且跳到步驟5、

   4、如果是硬體的問題,複製一個好的控制檔案拷貝到一個可靠的位置

   5、編輯initsid.ora 或者 configsid.ora,更新CONTROL_FILES以反映最新的控制檔案位置

   6、啟動資料庫

  事件6:丟失全部的控制檔案

  可以採用以下的步驟恢複:

   1、關閉資料庫

   2、進行一次全Database Backup,包括全部的資料檔案和redo log檔案

   3、以NOMOUNT的狀態啟動資料庫

   4、使用CREATE CONTROLFILE重新建立控制檔案、你也可以備份控制檔案到一個trace檔案,然後執行該檔案

   5、在資料庫上進行媒體恢複

   6、開啟資料庫

   7、使用shutdown normal關閉資料庫

   8、對資料庫進行一次冷備份

  事件7:丟失一個索引

  最簡單的方法就是重新建立丟失的索引

  事件8:丟失一個非活動的redo log

  如果丟失redo資料,恢複將是不完全的,必須重新建立涉及的資料表空間。要重新建立資料表空間,可以使用全的資料庫匯出,這樣就可以很容易的匯入資料並且重新建立該資料表空間的對象。可以使用以下的步驟來恢複:

   1、通過Alter system來切換redo log檔案

   2、關閉資料庫

   3、startup mount資料庫

   4、離線刪除涉及的資料檔案

   5、開啟資料庫

   6、刪除使用者的資料表空間,包括其中的內容、

   7、通過全Database Backup重新建立資料表空間和其中的對象
 
  事件9:丟失活動的Redo log

  如事件8討論的一樣,如果丟失了redo資料,恢複將是不完全的,必須重新建立涉及的資料表空間、可以採用以下的步驟恢複:

   1、關閉資料庫

   2、startup mount資料庫

   3、離線刪除涉及的資料檔案

   4、開啟資料庫

   5、刪除使用者的資料表空間,包括其中的內容、

   6、通過全Database Backup重新建立資料表空間和其中的對象

  要注意的是活動的事務將會丟失

  事件10:丟失存檔的Redo log檔案

  如果存檔的redo log檔案丟失,應該馬上進行一次冷備份、最好也進行一次全資料庫匯出、沒有丟失的存檔redo log檔案的任何恢複都將是不完全的、

  事件11:丟失活動的復原段

  這裡指的是丟失一個復原段的一個資料檔案、這是一個危急的恢複過程,它主要是在於儲存活動的事務。這裡假定資料庫已經起來,而你想儲存當前啟動並執行事務。要使用以下的恢複過程,資料庫必須運行在archivelog模式下。

  可以使用以下步驟恢複:

   1、不要關閉資料庫、對於這種事件,資料庫啟動比關閉更容易解決問題、

   2、令屬於該資料檔案中的全部復原段離線

   3、刪除全部離線的復原段

   4、在上面的第2步中,如果復原段中有活動的事務,你將不能令它離線、可運行以下的查詢來查看哪些事物是活動的:

  如果上面的查詢沒有結果,那麼所有的復原段都是離線的,但是,如果上面的查詢返回一行或者多行,並且其狀態為PENDING OFFLINE,那麼可檢查這些復原段的ACTIVE_TX列、帶有0值的復原段將很快會離線;但是,非0的值表示上面有活動的事務,它們需要被提交或者復原、

   5、處理活動的事務、執行以下的查詢來查看哪些使用者的事務被指派到該復原段:

  在知道哪些使用者在"pending offline"的復原段上有活動的事務後,可以要求他們提交或者復原他們的事務,或者可以使用以下的命令殺掉它們的進程:

   ALTER SYSTEM KILL SESSION 'sid, serial#';

   6、在你處理完所有活動的事務後,執行以下的步驟:

    丟棄資料表空間及其中的全部內容

    重新建立復原資料表空間

    重新建立復原段,並且令它們線上

[NextPage]

事件12:丟失全部的復原段

  在這種事件下,將丟失全部活動的事務,並且需要重新建立復原段。這樣大的問題可能是由於一個硬體問題造成的,可以採用以下的步驟恢複:

[1] [2] 下一頁

正在看的ORACLE教程是:最佳化Oracle停機時間及資料庫恢複。
   1、關閉資料庫

   2、使用DBVERIFY驗證全部的資料檔案

   3、解決其它的硬體問題或者資料檔案損壞

   4、以startup mount的方式啟動資料庫執行個體

   5、在資料庫上執行媒體恢複
 
   6、開啟資料庫

   7、按需要建立新的復原段

  事件13:匯出檔案損壞

  如果匯出檔案不能用了,那麼應該冷備份資料庫並且進行一個全的資料庫匯出、這是假定資料庫自身沒有問題、如果資料庫也損壞了,那麼應該執行以下的步驟:

   1、ORA-1157錯誤資訊通常都表示一個或者多個的資料檔案損壞了。查明哪些表受到影響,它們應該是錯誤資訊中指明的資料檔案中的表格

   2、跳過壞的資料區塊,將資料由表格中選擇到暫存資料表格中、

   3、丟棄損壞的表

   4、將暫存資料表重新命名為丟棄的表

   5、重建立立受影響表上的全部索引

   6、使用VALIDATE STRUCTURE CASCADE的選項來分析全部損壞的表

  要注意的是損壞塊中資料將會丟失並且不能恢複

  事件14:在熱備份時關機

  如果在熱備份進行中的時候突然關機,其中的一些資料表空間將可能處在備份模式、當你嘗試開啟資料庫時,它將只能mount,並且指示某些資料表空間處於熱備份模式、由於資料庫不能開啟,你將不能讓資料表空間脫離熱備份模式、你可以使用以下的步驟恢複:

   1、startup mount資料庫

   2、查詢v$backup以查看哪些資料檔案處於ACTIVE狀態、

   3、通過使用命令ALTER DATABASE DATAFILE END BACKUP.來將這些資料檔案脫離備份模式

   4、開啟資料庫

  事件15:恢複到某個特別的時間點

  以下的步驟可用來執行point-in-time恢複

   1、關閉資料庫執行個體

   2、以NOMOUNT的狀態啟動資料庫執行個體

   3、使用UNTIL的選項來恢複資料庫

   4、開啟資料庫

   5、Shutdown NORMAL

   6、啟動資料庫執行個體

  事件16:恢複到一個特別的事件或者活動

  可以使用以下的步驟來恢複:

   1、關閉資料庫執行個體

   2、以NOMOUNT狀態啟動資料庫執行個體;

   3、使用UNTIL CANCEL來恢複資料庫,提供存檔的redo log檔案請求直到該活動/事件為止

   4、輸入CANCEL來取消恢複

   5、開啟資料庫;

   6、使用NORMAL的模式來關閉資料庫

   7、啟動資料庫執行個體

  結論
 
  高可用性對於任何的商業都是很重要的,ORACLE DBA可以通過一些計劃以確保停機時間最小化、這篇文章討論了不同的策略可以達到這個目的。

上一頁

上一頁 [1] [2]

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.