時(shí)間:2015-06-28 00:00:00 來(lái)源:IT貓撲網(wǎng) 作者:網(wǎng)管聯(lián)盟 我要評(píng)論(0)
一.總述
1.數(shù)據(jù)庫(kù)歸檔模式:
* 非歸檔模式:當(dāng)數(shù)據(jù)庫(kù)數(shù)據(jù)只讀不會(huì)改變時(shí),數(shù)據(jù)不會(huì)改變,數(shù)據(jù)庫(kù)適合用非歸檔模式,?? 這樣提高性能
* 歸檔模式:對(duì)于數(shù)據(jù)庫(kù)數(shù)據(jù)經(jīng)常變動(dòng),數(shù)據(jù)庫(kù)最好用歸檔模式,這樣可以盡量避免數(shù)據(jù)庫(kù) 數(shù)據(jù)丟失,使出現(xiàn)問(wèn)題時(shí)災(zāi)害降到最低
2.非歸檔模式與歸檔模式間的切換(在命令窗口下):
@檢查當(dāng)前日志操作模式
f:\>sqlplus sys/dba as sysdba
連接數(shù)據(jù)庫(kù)
sql>select log_mode from v$database;
@關(guān)閉數(shù)據(jù)庫(kù),后裝載數(shù)據(jù)庫(kù),只能在mount狀態(tài)下改變?nèi)罩静僮髂J?/p>
sql>startup mount
@改變?nèi)罩灸J?/p>
sql>alter database achivelog;(變?yōu)闅w檔方式,否則為nochivelog)
sql>alter database open;
3.查看歸檔模式相關(guān)信息:
@若采用默認(rèn)設(shè)置,歸檔日志位置在快速恢復(fù)區(qū)
@配置歸檔日志位置 log_archive_dest_n? (n=[1:10])
sql>alter system set
log_archive_dest_1 = 'location =c:\demo\archive [optional]';
sql>alter system set
log_archive_dest_2 = 'service =standby [mandatory] [reopen]';
其中:location 是本地
service? 是遠(yuǎn)程
optional 無(wú)論歸檔是否成功,都會(huì)覆蓋重做日志
mandatory只有成功歸檔才會(huì)覆蓋重做日志
reopen 重新歸檔時(shí)間間隔 默認(rèn)是300s
@顯示歸檔信息,即顯示顯示日志操作模式
sql>select name,log_mode from v$database;
@顯示歸檔日志信息
sql>select name,seqnce#,first_change# from v$archive_log;
seqnce#: 歸檔序列號(hào)
first_change# : 起始SCN值
@顯示歸檔日志位置
sql>select dest_name,destination,status from v$archive_dest;
dest_name 歸檔位置參數(shù)名
destination 位置
@顯示日志歷史信息
sql>select * from v$loghist;
threade# : 重做線程號(hào)
seqnce# : 日志序列號(hào)
first_change# : 起始SCN值
first_time : 起始SCN發(fā)生時(shí)間
switch_change : 切換SCN值
二.非歸檔模式下的備份與還原
. 日志采用覆蓋原有日志的方式存儲(chǔ)
. 出現(xiàn)介質(zhì)失敗時(shí),只能恢復(fù)到過(guò)去的完全備份點(diǎn)
. 數(shù)據(jù)庫(kù)OPEN狀態(tài)是,不能備份數(shù)據(jù)庫(kù)
. 必須先關(guān)閉數(shù)據(jù)庫(kù),再備份,且必須備份所有數(shù)據(jù),控制文件
1.備份==冷備份
@ 先關(guān)閉數(shù)據(jù)庫(kù)
sql>shutdown immediate
@ 拷貝所有數(shù)據(jù)文件,和控制文件
2.恢復(fù)
* 數(shù)據(jù)文件出現(xiàn)丟失,但備份以來(lái)的重做日志內(nèi)容尚未被覆蓋,此時(shí)可以完全恢復(fù)
@裝載數(shù)據(jù)庫(kù)
sql>startup force mount
@復(fù)制數(shù)據(jù)文件備份
@恢復(fù)數(shù)據(jù)文件
sql>recover datafile 1
@打開(kāi)數(shù)據(jù)庫(kù)
sql>alter database open;
* 備份文件的重做日志內(nèi)容已經(jīng)被覆蓋,則只能還原到備份點(diǎn)
@關(guān)閉數(shù)據(jù)庫(kù)
@復(fù)制所有數(shù)據(jù)和控制備份文件至原位置
@裝載數(shù)據(jù)庫(kù),執(zhí)行恢復(fù)命令
sql>startup mount
sql>recover database until cancel
提示控制文件不再使用原有重做日志
@用resetlogs選項(xiàng)打開(kāi)數(shù)據(jù)庫(kù)
sql>alter database open resetlogs;
三.歸檔模式
. 可以防止數(shù)據(jù)丟失
. 數(shù)據(jù)處于OPEN狀態(tài)時(shí)可以進(jìn)行備份
. 當(dāng)出現(xiàn)介質(zhì)失敗時(shí),除了SYSTEM表空間中的數(shù)據(jù)文件外其他的都可以在open狀態(tài)下恢復(fù)
. 可執(zhí)行完全恢復(fù),也可以恢復(fù)到備份點(diǎn)與失敗點(diǎn)之間的某時(shí)刻
1.備份
1)冷備份
shutdown后拷貝所需數(shù)據(jù)文件和控制文件
2)熱備份
@將數(shù)據(jù)庫(kù)設(shè)置為歸檔模式
@在數(shù)據(jù)庫(kù)上發(fā)出全局檢查點(diǎn),在所有的數(shù)據(jù)文件頭塊上加鎖
sql>alter database begin backup ;
@備份數(shù)據(jù)文件及控制文件
數(shù)據(jù)文件直接拷貝至其他目錄
控制文件需使用alter database backup controlfile
sql>alter database backup controlfile to 'd:\backup\demo.ctl';
@結(jié)束數(shù)據(jù)備份,為確保數(shù)據(jù)文件備份的同步性,還應(yīng)該歸檔當(dāng)前日志組
sql>alter database end backup;
sql>alter system archive log cuurent;
3)備份表空間
*脫機(jī)備份(表空間處于OFFLINE狀態(tài),SYSTEM表空間和正在使用的UNDO空間不能脫機(jī))
@確定表空間包涵的數(shù)據(jù)文件,如空間USERS
sql>select file_name from dba_data_files
where tablespace_name = 'users';
@設(shè)置表空間為脫機(jī)狀態(tài)
sql>alter tablespace users offline;
@復(fù)制數(shù)據(jù)文件
@設(shè)置表空間聯(lián)機(jī)
sql>alter tablespace users online;
*聯(lián)機(jī)備份
@確定對(duì)應(yīng)關(guān)系
@設(shè)置表空間為備份模式
sql>alter tablespace users begin backup ;
@復(fù)制數(shù)據(jù)文件
@設(shè)置表空間為正常模式
sql>alter tablespace users end backup ;
*處理聯(lián)機(jī)備份失敗
當(dāng)執(zhí)行聯(lián)機(jī)備份時(shí),若出現(xiàn)例程失敗,再次打開(kāi)數(shù)據(jù)庫(kù)時(shí),如果數(shù)據(jù)文件仍處于備??? 份狀態(tài),則會(huì)出錯(cuò),此時(shí)需要結(jié)束備份
@裝載數(shù)據(jù)庫(kù)
sql>startup force mount
@查看處于聯(lián)機(jī)備份狀態(tài)的所有數(shù)據(jù)文件
sql>select file# from v$backup where status = 'active';
@結(jié)束聯(lián)機(jī)備份狀態(tài)
sql>alter tablespace end backup
或alter tablespace datafile backup;
或recover datafile 序號(hào)
@打開(kāi)數(shù)據(jù)庫(kù)
sql>alter database open;
2.還原
1)完全恢復(fù)
相關(guān)命令:
recover database :恢復(fù)數(shù)據(jù)庫(kù)的多個(gè)數(shù)據(jù)文件(在MOUNT狀態(tài)下運(yùn)行)
recover tadaspace :恢復(fù)多個(gè)表空間的所有數(shù)據(jù)文件(在open狀態(tài)下運(yùn)行)
recover datafile :恢復(fù)一個(gè)或多個(gè)數(shù)據(jù)文件(在mount,open狀態(tài)下都可)
*在mount狀態(tài)下恢復(fù)數(shù)據(jù)文件(用于SYSTEM表空間恢復(fù))
@裝載數(shù)據(jù)庫(kù) mount狀態(tài)
@確定需要恢復(fù)的數(shù)據(jù)文件
sql>select file#,error from v$recover_file
@拷貝備份至原位置
@恢復(fù)數(shù)據(jù)庫(kù) recover..上述命令
@打開(kāi)數(shù)據(jù)庫(kù) alter database open;
*在open狀態(tài)下恢復(fù)關(guān)閉后意外對(duì)視的數(shù)據(jù)文件,此時(shí)數(shù)據(jù)庫(kù)將無(wú)法打開(kāi)
@裝載數(shù)據(jù)庫(kù) mount
@確定需要恢復(fù)的數(shù)據(jù)文件
@使相應(yīng)的數(shù)據(jù)文件脫機(jī)
sql>alter database datafile 4 offline;
@打開(kāi)數(shù)據(jù)庫(kù)
sql>alter database open
@復(fù)制數(shù)據(jù)備份文件
@恢復(fù)數(shù)據(jù)文件
@是數(shù)據(jù)文件聯(lián)機(jī) alter database datafile 4 online;
*在open狀態(tài)下恢復(fù)打開(kāi)時(shí)意外丟失的數(shù)據(jù)文件
@確定要恢復(fù)的數(shù)據(jù)文件
@使數(shù)據(jù)文件脫機(jī)
@復(fù)制數(shù)據(jù)文件
@恢復(fù)相應(yīng)的表空間或數(shù)據(jù)文件
@使相應(yīng)的表空間或數(shù)據(jù)文件聯(lián)機(jī)
*在open狀態(tài)下恢復(fù)未備份的數(shù)據(jù)文件(要求在歸檔模式下,新建數(shù)據(jù)文件,其從簡(jiǎn)歷? 開(kāi)始的所有歸檔日志必須全部存在)
@裝載數(shù)據(jù)庫(kù)
@確定要恢復(fù)的數(shù)據(jù)文件
@是數(shù)據(jù)文件脫機(jī)
@打開(kāi)數(shù)據(jù)庫(kù)
@重新建立數(shù)據(jù)文件
sql>alter database create datafile 'd:\demo\users01.dbf';
@恢復(fù)數(shù)據(jù)文件
@使數(shù)據(jù)文件聯(lián)機(jī)
2)不完全恢復(fù)
使用已備份的數(shù)據(jù)文件,歸檔日志,和重做日志,將數(shù)據(jù)庫(kù)恢復(fù)到備份點(diǎn)與失敗點(diǎn)之間???? 某個(gè)時(shí)刻的狀態(tài)
*恢復(fù)分類
基于時(shí)間的恢復(fù):誤刪除表,誤截?cái)啾?提交了錯(cuò)誤的數(shù)據(jù)
基于取笑恢復(fù):恢復(fù)到某個(gè)日志序列號(hào)之前的狀態(tài)
基于SCN的恢復(fù):恢復(fù)到特定SCN值的狀態(tài)
基于備份控制文件恢復(fù):表空間被意外刪除,或所有控制文件全部損壞
*不完全恢復(fù)指令
recover database until time
recover database until change
recover database until cancel
recover database .. using backup controlfile
*基于時(shí)間的恢復(fù)
關(guān)鍵詞標(biāo)簽:oracle,數(shù)據(jù)庫(kù)備份與還
相關(guān)閱讀
熱門文章 Oracle中使用alter table來(lái)增加,刪除,修改列的語(yǔ)法 oracle中使用SQL語(yǔ)句修改字段類型-oracle修改SQL語(yǔ)句案例 誤刪Oracle數(shù)據(jù)庫(kù)實(shí)例的控制文件 為UNIX服務(wù)器設(shè)置Oracle全文檢索
人氣排行 oracle中使用SQL語(yǔ)句修改字段類型-oracle修改SQL語(yǔ)句案例 Oracle中使用alter table來(lái)增加,刪除,修改列的語(yǔ)法 ORACLE SQL 判斷字符串是否為數(shù)字的語(yǔ)句 ORACLE和SQL語(yǔ)法區(qū)別歸納(1) oracle grant 授權(quán)語(yǔ)句 ORACLE修改IP地址后如何能夠使用 如何加速Oracle大批量數(shù)據(jù)處理 Oracle刪除表的幾種方法