⑴ 計算機專業發表論文
您好,
如果是計算機專業的同學可以建議做網路方面的論文研究,這方面比較熱門、資料繁多、可借鑒性強;
其他如資料庫較之演算法以及數據結構相對可參考資料更為多一些。
相關範文:
Oracle資料庫的備份和恢復The Backup and Restoration of Database Oracle
摘要:本文從Oracle的體系結構開始,由原理到實踐,論述了Oracle資料庫備份的方式和策略。包括IMP/EXP, RMAN,OS備份等。
Abstract: Starting from the architecture of ORACLE, this paper discusses the backup method and strategy of database Oracle, including IMP/EXP, PMAN and OS theoretically and practically.
關鍵字:Oracle, 備份, 恢復, RMAN
Keywords: Oracle; Backup; Restoration; RMAN
概述
在大型軟體運行系統中,存在著很多備份策略,如RAID技術,CLUSTER技術等等。很多時候,這些系統的備份就能夠解決資料庫備份的問題。但是,這種備份成本很高。同時,硬體的備份有時根本滿足不了現實的需要,如果用戶不小心誤刪了一個表,又想恢復的時候,資料庫的備份就變的重要了。
Introction: In the running system of some big software, there exist many backup strategies such as RAID technology and CLUSTER technology etc. In most cases, these system backup strategies can fulfill the database backup. However the cost is rather high. At the same time, hardware backup sometimes is far from the actual requirement. The database backup becomes very important when a table is deleted by accident and needs to be restored.
Oracle的運行方式
Oracle資料庫有兩種運行方式:一是歸檔方式(ARCHIVELOG),歸檔方式的目的是當資料庫發生故障時最大限度恢復資料庫,可以保證不丟失任何已提交的數據;二是不歸檔方式(NOARCHIVELOG),只能恢復資料庫到最近的回收點(冷備份或是邏輯備份)。根據資料庫的高可用性和用戶可承受丟失的工作量的多少,對於實時性要求高的資料庫,強烈要求採用為歸檔方式;不歸檔方式只用在那些開發和調試的資料庫等。
如何改變資料庫的運行方式,在創建資料庫時,作為創建資料庫的一部分,就決定了資料庫初始的存檔方式。一般情況下為NOARCHIVELOG方式。當資料庫創建好以後,根據我們的需要把需要運行在歸檔方式的資料庫改成ARCHIVELOG方式。 操作如下。
1. 關閉資料庫,備份已有的數據,改變資料庫的運行方式是對資料庫的重要改動,所以要對資料庫做備份,對可能出現的問題作出保護。
2. 修改初試化參數,使能自動存檔。
修改(添加)初始化文件init[SID].ora參數:
log_archive_start=true #啟動自動歸檔
log_archive_format=ARC%T%S.arc #歸檔文件格式
log_archive_dest=/archdir/arch #歸檔路徑
在8i中,可以最多有五個歸檔路徑,並可以歸檔到其它伺服器,如備用資料庫(standby database)伺服器。
3. 啟動Instance到Mount狀態,即載入資料庫但不打開資料庫。
$> svrmgrl
SVRMGRL> connect internal
SVRMGRL> startup mount
SVRMGRL> alter database archivelog; // 使資料庫運行在歸檔方式
SVRMGRL> alter database open;
Oracle的備份方案
按照備份的方式,可以分為邏輯備份、冷備份(離線備份)、熱備份(聯機備份),其中冷備份與熱備份又可以合稱為物理備份。按照備份的工具,可以分為EXP/IMP備份、操作系統備份、RMAN、第三方工具備份,如VERITAS等。下面分別介紹Oracle本身提供的幾種備份工具和操作。
1. EXP/IMP備份(邏輯備份)
EXP/IMP屬於邏輯備份的范疇,邏輯備份是指只備份資料庫中的數據但不記錄數據物理位置的一種備份。導出為資料庫作一個二進制的備份,並且這個備份只能由其姊妹程序imp(import)來讀取。具體的使用方法如下。(因為EXP和IMP使用上參數基本相同,所以只以EXP為例。)
EXP的命令格式和參數
格式:KEYWORD=value 或 KEYWORD=(value1,value2,...,valueN)
常式: EXP SCOTT/TIGER GRANTS=Y TABLES=(EMP,DEPT,MGR)
USERID 必須是命令行中的第一個參數
關鍵字 說明(默認) 關鍵字 說明(默認)
USERID 用戶名/口令 FULL 導出整個文件 (N)
BUFFER 數據緩沖區的大小 OWNER 所有者用戶名列表
FILE 輸出文件 (EXPDAT.DMP) TABLES 表名列表
COMPRESS 導入一個范圍 (Y) RECORDLENGTH IO記錄的長度
GRANTS 導出許可權 (Y) INCTYPE 增量導出類型
INDEXES 導出索引 (Y) RECORD 跟蹤增量導出 (Y)
ROWS 導出數據行(Y) PARFILE 參數文件名
CONSTRAINTS 導出限制 (Y) CONSISTENT 交叉表一致性
LOG 屏幕輸出的日誌文件 STATISTICS 分析對象 (ESTIMATE)
DIRECT 直接路徑 (N) TRIGGERS 導出觸發器 (Y)
FEEDBACK 顯示每 x 行 (0) 的進度 FILESIZE 各轉儲文件的最大尺寸
QUERY 選定導出表子集的子句
註:可以通過exp -help命令查看exp的使用方法;imp -help命令查看imp的使用方法.
2. 操作系統備份(冷備份和熱備份)
操作系統備份有兩類,冷備份(Cold backup)和熱備份(Hot backup)。操作系統備份和上面的邏輯備份有本質的區別,它將拷貝整個的數據文件。
冷備份
在文件級備份開始前資料庫必須徹底關閉。關閉操作必須用帶有normal、immediate、transaction選項的shutdown來執行。
資料庫使用的每個文件都被備份下來,這些文件包括: 所有數據文件、所有控制文件、所有聯機重做日誌文件和INIT.ORA文件(建議)。
作冷備份一般步驟是:
1) 正常關閉要備份的實例(instance);
2) 備份整個資料庫到一個目錄
3) 啟動資料庫
即:
SVRMGRL>connect internal
SVRMGRL >shutdown immediate
SVRMGRL >!cp <file> <backup directory>
or
SVRMGRL >!tar cvf /dbbak/fullbk.tar /u01/oracle/oradata/dbname
SVRMGRL >startup
熱備份
熱備份是當資料庫打開時的操作系統備份。熱備份只能用於ARCHIVELOG方式的資料庫。熱備份沒有必要備份聯機日誌,但必須是歸檔狀態,在實例恢復的時候,可能需要用到歸檔日誌。當前聯機日誌一定要保護好或是處於鏡相狀態,當前聯機日誌的損壞,對於資料庫的損壞是巨大的,只能以數據的丟失來進行資料庫的恢復工作。對於臨時表空間,存放的是臨時信息,在熱備份是也可以考慮不用備份,如果臨時文件發生故障,可以刪除該數據文件與表空間,重建一個臨時表空間。
熱備份備份的內容和冷備份備份的內容一樣,操作一般步驟是:
1) 備份的表空間通過使用ALTER TABLESPACE …… BEGIN BACKUP使表空間進入熱備份方式。
2) 用類似冷備份的操作系統命令對組成表空間的數據文件進行拷貝。
3) 使用ALTER TABLESPACE …… END BACKUP命令使表空間脫離熱備份方式。
4) 使用ALTER DATABSE …… BACKUP CONTROLFILE命令備份控制文件。
即:
SVRMGRL>connect internal;
SVRMGRL>alter tablespace User begin backup;
SVRMGRL>!cp /u01/oradata/dbname/user01.ora /dbbak/user01.ora
SVRMGRL>alter tablespace User end backup;
SVRMGRL>alter database backup controlfile to <fielname>;
or
SVRMGRL>alter database backup controlfile to trace;
注意:因為熱備份的時候,用戶還在操作資料庫,所以最好是讓每個表空間處於備份狀態的時間最短,這樣就要求一個表空間一個表空間的備份,不要一起使表空間處於備份狀態而同時拷貝數據文件。
3. RMAN
Recovery Manager(RMAN)是一個使DBA能很方便地對資料庫執行備份和恢復任務的Oracle應用工具,能夠提供DBA對企業資料庫備份與恢復操作的集中控制。RMAN只能用於ORACLE8或更高的版本中。它能夠備份整個資料庫或資料庫部件,其中包括表空間、數據文件,控制文件和歸檔文件。RMAN可以按要求存取和執行備份和恢復。
RMAN支持六種不通的類型的備份,經常用到的有兩種:
FULL 資料庫全備份,包括所有的數據塊。
INCREMENTAL 增量備份,是指只備份在同級別或更低級別上進行的前一次備份之後的作過改動的那些數據塊。這其中需要一個0級的增量作為增量的基礎,它備份包括全部曾經被資料庫使用過的數據塊(但不是完全資料庫備份)。RMAN共可以支持7級增量。
BACKUP,RESTORE,RECOVER是RMAN最基本的三個命令,分別可以進行資料庫的備份,復原以及恢復操作。 restore命令用於恢復來自備份集或映像拷貝的數據文件、控制文件或歸檔重做日誌。recovery命令用於進行介質恢復應用重做日誌文件。
RMAN的備份信息一般保存在恢復目錄中,恢復目錄也是一個資料庫,只不過這個資料庫用來保存備份信息,一個恢復目錄可以用來保存多個資料庫的備份信息。 RMAN也可以在沒有恢復目錄(NOCATALOG)下運行,這個時候備份信息保存在控制文件。這種情況比較危險,因為一旦控制文件被破壞,將導致所有資料庫備份信息的丟失和恢復的失敗,而且,沒有恢復目錄,很多RMAN的命令將不被支持。所以對於重要的資料庫,建議創建恢復目錄。
創建恢復目錄一般有以下步驟。(例子資料庫為db)
1) 為目錄創建一個單獨的表空間
SQL>create tablespace tsrman datafile 』/dbbak/rman/rsrman.dbf』 size 50M;
2) 創建RMAN用戶
SQL>create user rman identified by rman default tablespace rsrman temporary tablespace temp;
3) 給RMAN授予許可權
SQL>grant connect, resource, recovery_catalog_owner to rman;
4) 打開RMAN
$rman
5) 連接恢復目錄資料庫
RMAN>connect catalog rman/rman@db
6) 創建恢復目錄
RMAN>create catalog tablespace tsrman
在對某個資料庫進行備份之前,必須先在恢復目錄上注冊該資料庫,這一過程操作如下(假定目標資料庫連接字元串為db100)。
1) 連接到恢復目錄資料庫
$rman rman/rman@db
2) 在RMAN中連接到目標資料庫(即要進行備份的資料庫)
RMAN>connect target sys/change_on_install@db100
3) 注冊資料庫
RMAN>register database;
注冊完資料庫後,就可以進行資料庫的備份了。有完全資料庫備份、表空間備份、控制文件備份、和歸檔日誌備份等。操作分別如下。
1) 完全資料庫備份
要求:ARCHIVELOG模式,在DB OPEN的情況下進行資料庫完全備份。
RMAN>run{
allocate channel c1 type=disk;
backup database;
release channel c1;
}
2) 表空間備份
要求:ARCHIVELOG模式
RMAN>run{
allocate channel c1 type=disk;
backup tablespace 「ts_users」 filesperset 3 format 『aatst_%t%s.%p』;
release channel c1;
}
3) 控制文件備份
RMAN>run{
allocate channel c1 type=disk;
backup current controlfile tag=weekly_sat_backup;
release channel c1;
}
在對資料庫進行完全備份時,控制文件自動包含其中。也可以在表空間或數據文件的備份中包含一個控制文件。
RMAN>run{
allocate channel c1 type=disk;
backup tablespace 「ts_users」
filesperset 3 format 『aatst_%t%s.%p』;
include current controlfile;
release channel c1;
}
4) 歸檔日誌備份
通過查詢數據字典表V$ARCHIVED_LOG獲取要備份的日誌序列號,然後執行命令:
RMAN>run{
allocate channel c1 type=disk;
backup archivelog low logseq 3 high logseq 10 thread 1;
release channel c1;
}
Oracle的備份策略
正確的備份策略不僅能保證資料庫伺服器的24*7的高性能的運行,還能保證備份與恢復的快速性與可靠性。我們將以RMAN的多級增量備份作為一個備份策略的例子來討論。採用多級備份就是為了減少每天備份所需要的時間,而又保證系統有良好的恢復性。恢復時間與備份時間要有一個權衡。比如只要進行一個資料庫的全備份,然後就只備份歸檔也可以保證能把資料庫恢復到最新的狀態,但是這樣的恢復時間將是不可容忍的。多級備份也正是為了解決這種問題,結合某些應用的特點,可以採用如下的備份策略:
每個月做一個資料庫的全備份(包括所有的數據和只讀表空間);
每個星期一做一次零級備份(不包含只讀表空間);
每個星期三做一次一級備份;
每天做一次二級備份。
每天做一次恢復目錄的熱備份。
任何資料庫的更改需要重新同步CATALOG目錄並重新備份(如添加數據文件)或重新備份(如修改表空間為只讀)。
每次備份後都可以備份歸檔日誌或定期備份歸檔日誌。如果可能,可以直接備份到磁帶上。
Oracle的恢復
下面的操作約定恢復目錄存儲在db118中,目標資料庫是db100。
1. 資料庫恢復
1) 啟動SQL*PLUS,使用正確的init.ora文件,使用NOMOUNT選項啟動目標資料庫實例。
2) 啟動RMAN並連接到恢復目錄,如下:
$rman catalog rman/rman@db118
恢復管理器: Release 9.2.0.1.0 - Proction
Copyright (c) 1995, 2002, Oracle Corporation. All rights reserved.
連接到恢復目錄資料庫
RMAN>
3) 連接到目標資料庫
RMAN>connect target internal/oracle@db100
連接到目標資料庫: db (DBID=1142471523)
4) 一旦連接到目標資料庫,執行restore命令執行全資料庫恢復
RMAN>run{
2>allocate channel c1 type disk;
3>restore database;
4>release channel c1;
}
2. 表空間和數據文件恢復
要執行表空間或數據文件恢復,資料庫必須以ARCHIVELOG模式運行,並且用戶需要擁有介質恢復所需的歸檔重做日誌文件。在試圖恢復表空間之前,必須保證表空間已離線。RMAN命令如下:
run{
allocate channel c1 type disk;
sql 「alter tablespace users_data offline immediate」;
restore tablespace users_data;
recover tablespace users_data;
sql 「alter tablespace users_data online」;
}
上面的腳本執行了以下的工作:
1) RMAN分配通道從c1用於恢復操作。
2) 將表空間users_data離線
3) RMAN從備份集中恢復屬於表空間的數據文件
4) 通過介質恢復提供所需的歸檔日誌文件,恢復屬於表空間users_data的數據文件。
5) RMAN將表空間聯機。
在腳本執行期間,如果不能把數據文件恢復到指定位置,在執行restore命令前使用set newname命令。
3. 控制文件恢復
1) 啟動SQL*PLUS,使用正確的init.ora文件,使用NOMOUNT選項啟動目標資料庫實例。
2) 啟動RMAN並連接到恢復目錄,如下:
$rman catalog rman/[email protected]
恢復管理器: Release 9.2.0.1.0 - Proction
Copyright (c) 1995, 2002, Oracle Corporation. All rights reserved.
連接到恢復目錄資料庫
RMAN>
3) 連接到目標資料庫
RMAN>connect target internal/[email protected]
連接到目標資料庫: db (DBID=1142471523)
4) 一旦連接到目標資料庫,執行restore命令恢復控制文件
RMAN>run{
2>allocate channel c1 type disk;
3>restore controlfile;
4>}
小結
保證Oracle資料庫的安全是系統安全的重要組成部分,必須要設計完善的資料庫備份和恢復方案。Oracle提供的各種工具結合起來使用能夠使資料庫的備份和恢復變得簡單。在實際的Oracle資料庫的備份和恢復中,會有許多不通的和復雜的情況出現,針對不同的情況,要本著使數據具有最大的可恢復性和恢復時間最短的原則去進行資料庫的恢復,這需要大量的實踐和經驗積累。
參考文獻
[1] Oracle8i Backup and Recovery Guide Oracle Document
[2] Oracle8i Recovery Manager User』s Guide and Reference Oracle Document
[3] Oracle9i:A Beginner』s Guide (美) Michael Abbey Michael Corey Ian Abramson 2002.3 機械工業出版社
[4] Oracle8i備份與恢復手冊 (美)Rama Velpuri Anand Adkoli 蔣蕊 王磊等譯 2001.9 機械工業出版社
僅供參考,請自借鑒
希望對您有幫助
⑵ 請問Oracle中RMAN怎麼用命令刪除7天前的數據文件副本
在命令窗口裡面執行
DELETE ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-7';
說明
SYSDATA-7,表明當前的系統野歲櫻頌叢時間7天前,before關鍵字表示在7天前的歸檔日誌,如果使用了閃回功能,也會刪除閃回的數據。
同樣道理,也可以刪雀尺除從7天前到現在的全部日誌,不過這個命令要考慮清楚,做完這個刪除,最好馬上進行全備份資料庫
DELETE ARCHIVELOG FROM TIME 'SYSDATE-7';
UNIX/LINUX下也可以通過FIND找到7天前的歸檔數據,使用EXEC子操作刪除
find /oraarchive -xdev -mtime +7 -name "*.dbf" -exec rm -f {} ;
這樣做仍然會在RMAN里留下未管理的歸檔文件
仍需要在RMAN里執行下面2條命令
crosscheck archivelog all;
delete expired archivelog all;
所以還不如上面的方法好用,不過用FIND的好處就是,可以在條件上,和EXEC子項上做很多操作,實現更復雜的功能
⑶ 如何查詢資料庫恢復需要用到哪些歸檔日誌
1、常氏巧談用命令 SQL> show parameter log_archive_dest; SQL> archive log list; SQL> select * from V$FLASH_RECOVERY_AREA_USAGE; ARCHIVELOG 96.62 0 141 SQL> select sum(percent_space_used)*3/100 from v$flash_recovery_area_usage; 2.9904 SQL> show parameter recover; db_recovery_file_dest string /寬嫌u01/oracle/flash_recovery_area db_recovery_file_dest_size big integer 2G 2、刪除日誌 cd $ORACLE_BASE/flash_recovery_area/orcl/archivelog 轉移或清除對應的歸檔日誌, 刪除一些不用的日期目錄的文件,注意保留最後幾個文件在刪除歸檔日誌後,必須用RMAN維護控制文件,否則空間顯示仍然不釋放。 3、rman target sys/password RMAN> crosscheck archivelog all; RMAN> delete expired archivelog all; 或者 RMAN> delete archivelog until time 「sysdate-1″; 4、再查 SQL> select * from V$FLASH_RECOVERY_AREA_USAGE; 5、修改殲碰大小 SQL> alter system set db_recovery_file_dest_size=4G scope=both;
⑷ Oracle資料庫如何開啟自動歸檔
Oracle
Enterprise
Manager
Console——某一個資料庫——例扒薯祥程——配置——恢復——「歸檔日誌模式」(自動歸檔);
常式——配置——一般信息——所有初始化參數——log_archive_start=true
歸檔信息可以通過如下語句查看
SQL
archive
log
list
Oracle資料庫可以運行在兩種模式下:歸檔模式(archivelog)和非歸檔模式(noarchivelog)。
檢查歸檔模式命令
SQL
archive
log
list
設置歸檔模式
SQL
shutdown
immediate;
SQL
startup
mount
SQL
alter
database
archivelog;
SQL
alter
database
open;
SQL
archive
log
list;
如果需要停止歸檔模式,使用:alter
database
noarchivelog
命令。Oracle10g之前,你還需要修改初始化參數使資料庫處於自動歸檔模式。在pfile/spfile中設置如下參數手吵
log_archive_start
=
true
重啟資料庫此參數生效,此時資料庫處於自動歸檔模式。也可以在資料庫啟動過程中,手工執行
archive
logstart使資料庫啟用自動歸檔,但是重啟後資料庫仍然處於手工歸檔模式
。10g使用db_recovery_file_dest來作為歸檔日誌的存放地。
SQL
show
parameter
db_recovery(
該語句在oracle11g下無春搏效)NAME
TYPEVALUEdb_recovery_file_dest
string
/home/oracle/ora10g/flash_reco
very_area/
⑸ oracle 在rman怎麼執行select語句
在手動恢復資料庫時,有時候需要在SQL*Plus提示符以及操作系統提示符,RMAN提示符下來回切換顯得有些繁瑣。實際上RMAN為我們提供了命令行下執行一些簡單的SQL語句以及PL/SQL的方法,以避免上述情形。本文描述了RMAN提示符下的一些常用命令及其用法。
1、RMAN提示符下執行SQL語句
語法: SQL '<command>' ;
語法比較簡單,就是提示符下輸入SQL,後接SQL命令,命令用單引號括起來
command 通常為可執行的SQL命令語句,也可以為PL/SQL塊
使用限制
如果SQL語句中包含文件名,則文件名及路徑需要使用兩個單引號括起來,整個SQL語句首尾需要使用雙引號
可以執行SQL查詢語句,但是無任何結果輸出
RMAN提示符下常用的命令
⑹ db_recovery_file_dest_size 位元組 (共 21474836480 位元組) 已使用 100.00%, 尚有 0 位元組可用
方法1 將歸檔設置到其他目錄
修改alter system set log_archive_dest = 其他吵絕路徑
方法2、也可以使用增大閃回恢復區的方法來解決
查看閃回恢復區設置:
show parameter db_recovery_file_dest_size
修改閃回恢復區大小:
alter system set db_recovery_file_dest_size=3G;
方法3 刪除閃回恢復區里的歸檔日誌。
用rman來刪除這些信息。所用到的rman命令如下:
1.是RMAN> crosscheck archivelog all;--此命令的含義是檢查所有歸檔日誌的狀態,並把遺失的標記為expired,也就是說,expired 表示已經被操作系統中改核被刪除的歸檔日誌核碰掘。
2.是delete expired archivelog all; --此命令的含義是刪除expired的歸檔日誌。
⑺ Oracle 資料庫 如何物理刪除 db_recovery_file_dest 的內容
首先確定你的 db_recovery_file_dest 是用於存放歸檔日誌嗎?如果是,那麼可以採用兩種方法:
1、直接在操作系統中cd到衡租這個目錄去知蘆刪除下面的歸檔日誌文件(rm命令)。(這是在沒有備份、不需要備份時使用的)
2、使用rman命令備份後刪除:
rman target /
rman>backup archivelog all
format '/你的備份目錄/%T/orclarchbk_%d_%T_%s'咐猛兆 delete input;
⑻ 關於oracle備份問題,請問oracle 的熱備份和冷備份的區別以及各自的好處
熱備份支持在資料庫不停機的情況下進行備份,冷備份是必須在資料庫shutdown以後使用操作系統的命令對表空間進行拷貝進行的備份。
熱備份適用於重要的資料庫,比如7x24不能中斷的生產系統,同時可以保證資料庫在出現崩潰時結合歸檔日誌可以恢復到任意一個時間點,不會造成數據丟失。
冷備份在資料庫出現問題是 只會恢復到備份時的那一時間點,備份完成到資料庫出現問題需要恢復棚嫌時的這一時間段內的所有新數據、修改記錄都無法恢復。
熱備份只能在歸檔模式下進行,冷備份不需要歸檔模式,歸檔模式會對系統性能尤其是磁碟I/O造成一定源和銷的影響,但是相對於歸雹游檔的好處和安全性,相信大多數DBA都會選擇歸檔模式。
⑼ 怎麼檢查rman備份是否成功
1、埋渣restore preview命令
此命令用來查看還原需要使用哪個備份集來執彎中悄行特定的恢復
restore database preview;
2、使用validate和check logical參數的restore命令,檢查備份集,以確認資料庫是可恢復的
restore database validate;
使用check logical參數可以更完全的檢查最新備份集
run
{
restore database check logical validate;
}
3、使用validate backupset命令
使用具有validate參數或check logical參數培帆的restore命令只能檢查最新的備份集,如果要檢查任意的備份集,就需要用validate backupset命令。
首先必須確認要檢查的備份集的鍵(backup set key)
list backupset;
再執行檢查
validate backupset 141;
或
validate backupset 141 check logical;