首頁 資料庫 mysql教程 备份恢复4.2rman恢复基础概念

备份恢复4.2rman恢复基础概念

Jun 07, 2016 pm 03:37 PM
基礎 備份 恢復 概念

rman恢复与用户管理的备份恢复一样,都分为完全恢复和不完全恢复,都需要工作在archivelog模式下。 rman10g之后只保留了0级和1级备份,1级备份分为:cumulative(累积增量)和differential(差异增量)两种模式,如果不加关键词默认是差异增量备份: backup

rman恢复与用户管理的备份恢复一样,都分为完全恢复和不完全恢复,都需要工作在archivelog模式下。

rman10g之后只保留了0级和1级备份,1级备份分为:cumulative(累积增量)和differential(差异增量)两种模式,如果不加关键词默认是差异增量备份:

backup incremental level 1 cumulative database(累积增量)

backup incremental level 1 database(差异增量)


连接:

rman

connect target /

@/mydir/lyg.txt

或者:

rman @/mydir/lyg.txt


1、rman转储命令:

当使用rman执行介质恢复时,首先需要用restore命令来完成转储备份文件的,执行restore命令时,rman自动转储最近备份的文件。

restore database : 转储数据库的所有数据文件,当数据库的所有数据文件都出现介质失败,或者执行不完全恢复时,应该使用restore database 命令转储所有数据文件,此命令只能在mount状态下使用。


restore tablespace :用于转储特定表空间的数据文件,如果某个表空间的所有数据文件都出现介质失败,并且数据库处于open阶段,那就应该使用restore tablespace命令。该命令只能在open状态下使用。


restore datafile:转储特定数据文件,该命令既可以在mount状态下,也可以在open状态下使用。


restore controlfile: 该命令用于转储控制文件,当执行基于控制文件的不完全恢复或者将数据库恢复到先前副本状态时,必须转储控制文件,restore controlfile 命令只能在nomount状态下使用。


restore archivelog:转储归档日志,当执行完全恢复和不完全恢复时,都需要应用归档日志。如果归档日志出现介质失败,或者归档日志的映像副本不存在,那么应该使用restore archivelog命令转储归档日志,注意,该命令既可以在mount状态下使用,也可以在open状态下使用。


restore spfile: 转储服务器参数文件。如果服务器参数文件出现介质失败,那么可以使用restore spfile命令进行转储。该命令只能在nomount状态使用。


2、rman恢复命令:

当执行介质恢复时,在转储了数据文件备份之后,需要应用归档日志恢复数据文件,恢复数据文件是使用recover命令来完成的,当执行recover命令时,rman会自动应用自 最近备份以来的所有归档日志。


recover database : 用于恢复数据库所有的数据文件,当使用restore database命令转储了所有的数据文件备份之后,应该使用recover database命令执行恢复,注意该命令只能在mount状态下使用。


recover tablespace: 恢复特定表空间的数据文件,先用restore tablespace命令转储,然后使用recover tablespace执行恢复。注意,该命令只能在open状态下。


recover datafile: 该命令既可以在mount状态下,也可以在open状态下使用。


恢复数据库:

通过查询动态性能视图 v$recover_file可以确定需要恢复的数据文件:

SQL> startup            —— 数据库显示mounted 但是open时出错

SQL> select file#, error from v$recover_file;            ——查询需要恢复的文件,以及出错的原因


示例一 :所有数据文件被误删除:因为所有数据文件全部被误删除,所以可以使用restore database 命令转储所有数据文件,在使用recover database 命令恢复数据库,最后执行 alter database open打开数据库:

C:\> rman target sys/liu123@mynewdb  nocatalog

RMAN> startup force mount

RMAN>run{ restore database;

 recover database;

 sql 'alter database open ';

}


示例二:数据文件所在磁盘出现硬件故障:

需要注意,数据文件此事将不能被转储到其原来的位置,为了恢复数据库,必须将数据文件转储到其他磁盘。在执行restore database 命令之前,通过执行set newname命令可以为数据文件指定新的位置。在执行restore database 命令之后,通过执行switch datafile命令,可以改变控制文件所记载的数据文件位置和名称,在通过执行recover database命令可以应用归档日志。最后用sql语句打开数据库。示例:

RMAN> run{

 startup force mount;

set newname for datafile 1 to 'c:\demo\system01.dbf';

set newname for datafile 2 to 'c:\demo\undotas01.dbf';

set newname for datafile 3 to 'c:\demo\sysaux01.dbf';

set newname for datafile 4 to 'c:\demo\users01.dbf';

set newname for datafile 5 to 'c:\demo\user01.dbf';

set newname for datafile 6 to 'c:\demo\user02.dbf';

restore database;

switch databse;

sql 'alter database open'

}

在恢复并打开数据库之后,执行report schema命令可以查看到数据库新的物理方案

RMAN> report schema;


恢复system表空间的数据文件:

因为system表空间出现介质失败时,数据库不能被打开,所以必须在mount状态下恢复其数据文件。


示例一:system表空间的数据文件被误删除,在装载了数据库之后,先使用restore datafile 命令转储该表空间所对应的数据文件,在使用recover datafile 命令应用归档日志。最后打开数据库。命令:

RMAN> run{

 startup force mount;

 restore datafile 1 ;

recover datafile 1 ;

sql 'alter database open'

}


示例二:system表空间数据文件所在磁盘出现故障,肯定不能转储到原来位置,在restore datafile之前,执行set newname为数据文件指定新的位置。执行完restore datafile之后,通过switch datafile可以应用归档日志,最后打开数据库。示例:

RMAN>  run {

 startup force mount;

set newname for datafile 1 to 'd:\demo\system01.dbf';

restore datafile 1 ;

switch datafle 1;

 recover datafile 1;

sql 'alter database open';

}


在open状态下恢复关闭后意外丢失的数据文件:

除了system 表空间的数据文件之外,其他数据文件都可以使用该方法进行恢复:


示例一:数据文件被误删除:装载数据库之后,先使用sql语句alter database datafile 。。。offline脱机丢失的数据文件,接着alter database open 打开数据库。,再使用restore datafile命令转储数据文件,使用recover datafile 命令应用归档日志。,最后再 alter database datafile 。。online恢复联机、示例:

RMAN > run {

 startup force mount;

 sql ‘ alter database datafile 4 offline’;

 sql 'alter database open';

 restore datafile 4;

 recover dtafile 4;

 sql 'alter database datafile 4 online';

}


示例二:数据文件所在的磁盘出现损坏:

很显然数据文件不能被转储到原来的位置。首先装载数据库,然后alter database datafile 。。 offline 。然后alter database open。 在restore datafile之前,先set newname 命令为数据文件制定新的位置,在执行了restore datafile命令之后,用switch datafile 命令可以改变控制文件所记载的数据文件的位置和名称,在通过recover datafile 命令可以应用归档日志。最后alter database datafile 。。 online联机。示例代码:

RMAN > run{

startup force mount;

sql 'alter databse datafile 4 offline';

sql 'alter database open ';

set newname for datafile 4 to 'd:\demouser01.dbf';

restore datafile 4;

switch datafile 4;

recover datafile 4;

sql 'alter database datafile 4 onlune';

}


在open状态下恢复打开时意外丢失的数据文件:

此时,只有出现介质失败的数据文件不能访问,而不影响其他数据文件,假定在open状态下users01,.dbf出现介质失败。

示例一:数据文件被误删除:先在open状态下alter database datafile 。。offline ,使用restore datafile 命令转储数据文件,再recovert datafile应用归档日志,最后alter database datafile 。。online使数据文件联机:

RMAN>run {

sql 'alter database datafile 4 offline';

restore datafile 4;

recover datafile 4;

sql 'alter database datafile 4 online';

}


示例二:数据文件所在磁盘出现故障:不能讲数据文件转储到原来位置,首先alter database datafile 。。offline 。然后set newname for 命令为数据文件指定新位置。然后restore datafile,再switch datafile 更改控制文件中数据文件的名称和位置。再使用recover datafile应用归档日志。最后alter database datafile 。。online。示例:

RMAN > run {

sql ' alter database datafile 4 offline';

set newname for datafile 4 to 'd:\demo\users01.dbf';

restore datafile 4;

switch datafile 4;

recover datafile 4;

sql 'alter database datafile 4 online';

}


在open状态下恢复未备份的数据文件:

示例一:数据文件被误删除:

注意此时数据文件并没有备份,从10g开始,如果数据文件备份不存在,那么转储数据文件时会自动建立数据文件,建立了数据文件之后,就可以根据归档日志跑日志,一直恢复到删除文件的时间点。示例:

RMAN>run {

 starup force mount;

sql 'alter database datafile 7 offline';

sql 'alter database open';

restore datafile 7;

recover datafile 7;

sql 'alter database datafile 7 online';

}


示例二:数据文件所在磁盘损坏。

RMAN>run{

startup force mount ;

sql 'alter database datafile 7 offline';

sql 'alter database open';

set newname for datafile 7 to 'c:\demo\user04.dbf';

restore datafile 7;

switch datafile 7;

recover datafile 7;

sql 'alter database datafile 7 online';

}



恢复表空间:

示例一:数据库处于open状态下,如果某个表空间所有数据文件出现介质故障,首先要使用alter tablespace 。。offline for recover来脱机表空间。接着使用restore tablespace 。。再revover tablespace应用归档日志,最后alter tablespace 。。online 。示例:

RMAN > run{

 sql ' alter tablespace users offline for recover';

 restore tablespace users;

 recover tablespace users;

 sql ' alter tablespace users online';

}


示例二:表空间数据文件所在磁盘故障:

RMAN> run{

 sql 'alter tablespace users offline for recover';

 set newname for datafile 4 to  'd:\demo\users01.dbf';

 restore tablespace user;

 switch datafile all;

recover tablespace users;

sql 'alter tablespace users online';

}



数据块介质恢复:

只有当访问到这些坏块的时候才会报错。如报错:

ora-01578:oracle data block corrupted (file# 5, block# 21)

ora-01110:data file 5 :’d:\demo\uyser01,dbf‘

使用命令如下:RMAN >  blockrecover device type disk datafile 5 block 21 ,48 ,128;



RMAN不完全恢复:

rman的不完全恢复能在mount状态下完成。

1、基于时间恢复:当rman执行基于时间点的 不完全恢复时,首先要在命令行设置环境变量NLS_DATE_FORMAT。进入rman之后,先mount数据库,再使用SET UNTIL TIME 命令执行要恢复到的时间点。示例:

C:\> set nls_date_format = yyyy-mm-dd hh24:mi:ss

C:\>rman target sys/oracle@demo nocatalog

RMAN > run{

startup force mount;

set until time = '2012-05-08 17:00:28';

restore database;

recover database;

sql 'alter database open resetlogs';

}


当使用resetlogs选项打开数据库之后,会复位日志序列号,并生成新的数据库副本,在10g之前,不完全恢复之后必须重新备份数据库,10g之后,oracle提供了安全机制可以确保归档日志不会被覆盖,从而使得在恢复数据库时可以使用早期数据库副本的备份,但在执行了不完全恢复之后,建议删除早期的所有备份,并重新备份数据库。示例:

RMAN > run {

 delete  noprompt backup;

 delete noprompt copy;

 backup database format =’d:backup\%d_%s.bakj‘;

 sql 'alter system archive log current';

}


基于SCN的恢复:


首先查询当前scn号:SQL> select current_scn from v$databse;

然后删除一个表scott.emp。

示例如下:RMAN > run{

 startup force mount;

set until scn = 511416;

restore database;

recover database;

sql 'alter database open resetlogs';

}


当使用resetlogs选项打开数据库之后,会复位日志序列号,并生成新的数据库副本,在10g之前,不完全恢复之后必须重新备份数据库,10g之后,oracle提供了安全机制可以确保归档日志不会被覆盖,从而使得在恢复数据库时可以使用早期数据库副本的备份,但在执行了不完全恢复之后,建议删除早期的所有备份,并重新备份数据库。示例:

RMAN > run {

 delete  noprompt backup;

 delete noprompt copy;

 backup database format =’d:backup\%d_%s.bakj‘;

 sql 'alter system archive log current';

}



基于日志序列号恢复:

假定我们在执行完全备份恢复失败时,出现了如下错误备份恢复4.2rman恢复基础概念

这种情况下dba可以实用基于日志序列号的不完全恢复:示例:

RMAN > run{

startup force mount;

set until sequence = 6;

restore database;

recover database;

sql ’alter database open resetlogs‘;

}


当使用resetlogs选项打开数据库之后,会复位日志序列号,并生成新的数据库副本,在10g之前,不完全恢复之后必须重新备份数据库,10g之后,oracle提供了安全机制可以确保归档日志不会被覆盖,从而使得在恢复数据库时可以使用早期数据库副本的备份,但在执行了不完全恢复之后,建议删除早期的所有备份,并重新备份数据库。示例:

RMAN > run {

 delete  noprompt backup;

 delete noprompt copy;

 backup database format =’d:backup\%d_%s.bakj‘;

 sql 'alter system archive log current';

}



基于备份控制文件恢复:

是指实用备份控制文件恢复数据库的过程,当误删除了表空间或者数据库所有控制文件全部损坏时,可以使用这种方法。下面模拟dba用户删除了users表空间为例,说明基于备份控制文件恢复的方法;

SQL> drop tablespace user01 including contents;

通过查询alert文件可以确定误操作时间,alert文件位置:background_dump_dest所对应的目录中,文件名格式:alert_mynewdb.log查看alert文件时,应该有文件尾部向上查看,可以看到删除该表的具体时间,大概为2012-05-08 22:13:34 ,只要恢复到该时间点就可以了,注意:当使用基于备份控制文件的rman不完全恢复时,必须使用恢复目录,将控制文件内的rman元数据周期性写到恢复目录中去,如果没有使用恢复目录,那就要求激活控制文件自动备份功能,否则就不能转储控制文件备份,转储控制文件之前,需要使用set dbid命令,设置数据库id编号,在转储了控制文件之后装载数据库,然后执行基于时间点的rman不完全恢复。示例:

C:\> set nls_date_format = yyyy-mm-dd hh24:mi:ss

C:\>rman target sys/oracle@demo nocatalog

RMAN > startup force nomount

RMAN > set dbid = 3282656886;

RMAN > restore controlfile from autobackup maxseq 6;

RMAN > alter database mount

RMAN >run{

set until time = '2012-05-08 22:13:34';

restore database;

recover database;

sql 'alter database open resetlogs';

}


当使用resetlogs选项打开数据库之后,会复位日志序列号,并生成新的数据库副本,在10g之前,不完全恢复之后必须重新备份数据库,10g之后,oracle提供了安全机制可以确保归档日志不会被覆盖,从而使得在恢复数据库时可以使用早期数据库副本的备份,但在执行了不完全恢复之后,建议删除早期的所有备份,并重新备份数据库。示例:

RMAN > run {

 delete  noprompt backup;

 delete noprompt copy;

 backup database format =’d:backup\%d_%s.bakj‘;

 sql 'alter system archive log current';

}

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

微信檔案過期怎麼恢復 微信的過期檔案能恢復嗎 微信檔案過期怎麼恢復 微信的過期檔案能恢復嗎 Feb 22, 2024 pm 02:46 PM

開啟微信,在我中選擇設置,選擇通用後選擇儲存空間,在儲存空間選擇管理,選擇要恢復檔案的對話選擇感嘆號圖示。教學適用型號:iPhone13系統:iOS15.3版本:微信8.0.24解析1先開啟微信,在我的頁面中點選設定選項。 2接著在設定頁面中找到並點選通用選項。 3然後在通用頁面中點選儲存空間。 4接下來在儲存空間頁面中點選管理。 5最後選擇要恢復檔案的對話,點選右側的感嘆號圖示。補充:微信文件一般幾天過期1要是微信接收的文件並沒有點開過的情況下,那在七十二鐘頭之後微信系統會清除掉,要是己經查看了微信

如何恢復無痕模式下的瀏覽記錄 如何恢復無痕模式下的瀏覽記錄 Feb 19, 2024 pm 04:22 PM

無痕瀏覽是一種非常方便的瀏覽方式,可以在使用電腦或行動裝置上網時保護個人隱私。無痕瀏覽模式通常會阻止瀏覽器記錄存取歷史記錄、保存Cookie和快取文件,以及防止正在瀏覽的網站在瀏覽器中留下任何痕跡。但是,對於一些特殊的情況,我們可能需要恢復無痕瀏覽的瀏覽記錄。首先,我們需要先明確一點:無痕瀏覽模式的目的是保護隱私,防止他人從瀏覽器取得使用者的上網記錄。因此,無痕瀏

如何備份谷歌瀏覽器的擴充程序 如何備份谷歌瀏覽器的擴充程序 Jan 30, 2024 pm 12:36 PM

谷歌瀏覽器擴充功能如何備份?對於大多數Google瀏覽器用戶來說,日常使用時會安裝或多或少的插件,插件的存在可以提升我們的使用體驗。當我們重裝系統或瀏覽器時,這些插件卻無法保留,重新下載安裝又比較麻煩,那麼有沒有辦法備份目前已安裝的插件呢?下面就為大家帶來操作方法。備份chrome插件的教學方法先打開Google瀏覽器,點擊右上角的選單,選擇更多工具-擴充功能。點擊擴充功能頁面上方的打包擴充功能。在C:UsersAdministratorAppDataLocalGoogleChromeUserDataDe

抖音怎麼恢復聊天火花 抖音怎麼恢復聊天火花 Mar 16, 2024 pm 01:25 PM

在抖音這個充滿創意與活力的短影片平台上,我們不僅可以欣賞到各種精彩內容,還能與志同道合的朋友展開深入的交流。其中,聊天火花作為衡量雙方互動熱度的重要指標,常常在不經意間點燃我們與好友之間的情感連結。然而,有時由於一些原因,聊天火花可能會斷開,那麼如果我們想要恢復聊天火花究竟該如何操作呢,這篇教程攻略就將為大家帶來詳細的內容攻略介紹,希望能幫助到大家。抖音聊天火花斷了怎麼恢復? 1.開啟抖音的訊息頁面,選擇好友聊天。 2、互發訊息聊天。 3.連續發送訊息3天,就可以獲得火花標識。在3天基礎上,互發圖片或視

小米雲相簿怎麼恢復到本地 小米雲相簿怎麼恢復到本地 Feb 24, 2024 pm 03:28 PM

小米雲相簿怎麼恢復到本地?小米雲相簿APP中是可以恢復到本地,但是多數的小伙伴不知道小米雲相冊如何恢復到本地中,接下來就是小編為用戶帶來的小米雲相冊恢復到本地方法圖文教程,有興趣的用戶快來一起看看吧!小米雲相簿怎麼恢復到本地1、先打開小米手機中的設定功能,主介面選擇【個人頭像】;2、然後進入到小米帳號的介面,點選【雲端服務】功能;3、接著跳到小米雲端服務的功能,選擇其中的【雲端備份】;4、最後在如下圖所示的介面,點選【雲端相簿】即可恢復相簿到本地。

win10怎麼恢復預設壁紙 win10怎麼恢復預設壁紙 Feb 10, 2024 pm 10:51 PM

Windows10的2019年5月更新有新的、更亮的預設桌面背景。它看起來很棒-帶有新的淺色主題。如果您使用Windows10的深色主題,您可能需要更深的背景。奇怪的是,Windows10的原始桌面背景已從最新版本的Windows10中刪除。您必須從Web下載它或從舊的Windows10PC複製其檔案。儘管我們無法在Microsoft的官方網站上找到此桌布圖片,但您可以從其他來源下載它。我們在Imgur上找到了一份4K解析度的Windows10原始桌面桌布的副本。此外,還有其他尺寸和更多預設壁

如何在Windows 11的檔案總管中刪除啟動備份 如何在Windows 11的檔案總管中刪除啟動備份 Feb 18, 2024 pm 05:40 PM

如果您希望在Windows11的檔案總管中隱藏「開始備份」選項,以下是您可以採取的方法。有多種途徑可用於在檔案總管中停用或隱藏啟動備份選項,我們將簡要列出一些方法,以幫助您快速完成此任務。在開始之前,您需要了解這個選項與OneDrive密切相關。一旦您開啟某個庫資料夾(例如Document、Pictures、Music等),它會立即顯示在檔案總管的路徑中。如何在Windows11的檔案總管中刪除啟動備份要在Windows11的檔案總管中刪除啟動備份,請依照下列方法操

如何在 PHP 中使用 MySQL 備份和還原? 如何在 PHP 中使用 MySQL 備份和還原? Jun 03, 2024 pm 12:19 PM

在PHP中備份和還原MySQL資料庫可透過以下步驟實現:備份資料庫:使用mysqldump指令轉儲資料庫為SQL檔。還原資料庫:使用mysql指令從SQL檔案還原資料庫。

See all articles