使用Oracle自帶的備份恢復(fù)工具RMAN(Recovery Manager)具有以下幾種優(yōu)勢(shì):
支持增量備份
能自動(dòng)管理備份文件
自動(dòng)化備份與恢復(fù)
備份的文件有效性檢查
配置快閃恢復(fù)區(qū)(flash recovery area)
快閃恢復(fù)區(qū)是存儲(chǔ)備份和恢復(fù)數(shù)據(jù)文件以及相關(guān)信息的存儲(chǔ)區(qū)。需要設(shè)置兩個(gè)參數(shù):db_recovery_file_dest_size(快閃恢復(fù)區(qū)的大容量),db_recovery_file_dest(快閃恢復(fù)區(qū)所在的路徑)。
查看快閃恢復(fù)區(qū)信息:
SQL> show parameter db_recovery_file_dest; NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ db_recovery_file_dest string /data/app/oracle/recovery_area db_recovery_file_dest_size big integer 3882M修改快閃恢復(fù)區(qū)大小:
SQL> alter system set db_recovery_file_dest_size=2g; System altered. SQL> show parameter db_recovery_file_dest; NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ db_recovery_file_dest string /data/app/oracle/recovery_area db_recovery_file_dest_size big integer 2G查看使用情況:
SQL> select name,space_limit,space_used,number_of_files from v$recovery_file_dest; NAME -------------------------------------------------------------------------------- SPACE_LIMIT SPACE_USED NUMBER_OF_FILES ----------- ---------- --------------- /data/app/oracle/recovery_area 2147483648 0 0顯示沒(méi)有使用。
也可以使用此命令查看詳細(xì)信息:
SQL> select file_type,percent_space_used,percent_space_reclaimable,number_of_files from v$flash_recovery_area_usage;建立RMAN到數(shù)據(jù)庫(kù)的連接
創(chuàng)建rman用戶,并授權(quán):
[oracle@temp-test oracle]$ sqlplus /nolog SQL> connect/as sysdba Connected. SQL> create user rman identified by oracle; User created. SQL> grant resource,connect,dba to rman; Grant succeeded. SQL> quit使用rman用戶登錄RMAN:
[oracle@temp-test oracle]$ rman target rman/oracle Recovery Manager: Release 11.2.0.1.0 - Production on Fri Nov 3 16:59:27 2017 Copyright (c) 1982, 2009, Oracle and/or its affiliates. All rights reserved. connected to target database: ORCL (DBID=1486802665) RMAN>也可以使用如下方式登錄:
[oracle@temp-test oracle]$ rman Recovery Manager: Release 11.2.0.1.0 - Production on Fri Nov 3 17:00:35 2017 Copyright (c) 1982, 2009, Oracle and/or its affiliates. All rights reserved. RMAN> connect target system/rman connected to target database: ORCL (DBID=1486802665) RMAN> connect target rman/oracle也可以使用操作系統(tǒng)認(rèn)證連接RMAN:
[oracle@temp-test oracle]$ rman target / Recovery Manager: Release 11.2.0.1.0 - Production on Fri Nov 3 17:02:52 2017 Copyright (c) 1982, 2009, Oracle and/or its affiliates. All rights reserved. connected to target database: ORCL (DBID=1486802665) RMAN>配置RMAN
查看RMAN的配置參數(shù):
RMAN> show all; using target database control file instead of recovery catalog RMAN configuration parameters for database with db_unique_name ORCL are: CONFIGURE RETENTION POLICY TO REDUNDANCY 1; # default CONFIGURE BACKUP OPTIMIZATION OFF; # default CONFIGURE DEFAULT DEVICE TYPE TO DISK; # default CONFIGURE CONTROLFILE AUTOBACKUP OFF; # default CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK TO '%F'; # default CONFIGURE DEVICE TYPE DISK PARALLELISM 1 BACKUP TYPE TO BACKUPSET; # default CONFIGURE DATAFILE BACKUP COPIES FOR DEVICE TYPE DISK TO 1; # default CONFIGURE ARCHIVELOG BACKUP COPIES FOR DEVICE TYPE DISK TO 1; # default CONFIGURE MAXSETSIZE TO UNLIMITED; # default CONFIGURE ENCRYPTION FOR DATABASE OFF; # default CONFIGURE ENCRYPTION ALGORITHM 'AES128'; # default CONFIGURE COMPRESSION ALGORITHM 'BASIC' AS OF RELEASE 'DEFAULT' OPTIMIZE FOR LOAD TRUE ; # default CONFIGURE ARCHIVELOG DELETION POLICY TO NONE; # default CONFIGURE SNAPSHOT CONTROLFILE NAME TO '/data/app/oracle/product/11.2.0/dbhome_1/dbs/snapcf_orcl.f'; # default參數(shù)含義:
CONFIGURE RETENTION POLICY TO REDUNDANCY 1
保留的備份副本數(shù)量,表示只保留一個(gè)數(shù)據(jù)文件的副本,并且保留最新的備份副本。
CONFIGURE DEFAULT DEVICE TYPE TO DISK
數(shù)據(jù)文件默認(rèn)備份到磁盤(pán)上,也可以是其他設(shè)備如磁帶(sbt)
CONFIGURE BACKUP OPTIMIZATION OFF
不使用備份優(yōu)化,啟用備份優(yōu)化的作用是如果已經(jīng)備份了某個(gè)文件的相同版本,則不會(huì)再備份該文件。,只保留一份備份文件。
CONFIGURE CONTROLFILE AUTOBACKUP OFF
不啟動(dòng)控制文件的自動(dòng)備份,修改為ON之后,如果數(shù)據(jù)庫(kù)結(jié)構(gòu)發(fā)生變化或者在備份數(shù)據(jù)庫(kù)過(guò)程中,控制文件會(huì)自動(dòng)再備份到指定目錄下
CONFIGURE DEVICE TYPE DISK PARALLELISM 1 BACKUP TYPE TO BACKUPSET
備份通道數(shù)量為1,默認(rèn)使用備份集的方式。通道數(shù)量越多,執(zhí)行任務(wù)時(shí)間越短。
如果要修改參數(shù),可以執(zhí)行如下命令:
開(kāi)啟備份優(yōu)化:
RMAN> CONFIGURE BACKUP OPTIMIZATION ON; new RMAN configuration parameters: CONFIGURE BACKUP OPTIMIZATION ON; new RMAN configuration parameters are successfully stored設(shè)置備份類型為Copy,也就是映像模式:
RMAN> CONFIGURE DEVICE TYPE DISK BACKUP TYPE TO COPY; new RMAN configuration parameters: CONFIGURE DEVICE TYPE DISK BACKUP TYPE TO COPY PARALLELISM 1; new RMAN configuration parameters are successfully stored備份控制文件到快閃恢復(fù)區(qū):
RMAN> backup current controlfile; Starting backup at 03-NOV-17 using channel ORA_DISK_1 channel ORA_DISK_1: starting datafile copy copying current control file output file name=/data/app/oracle/recovery_area/ORCL/controlfile/o1_mf_TAG20171103T180113_dzrhm9vk_.ctl tag=TAG20171103T180113 RECID=3 STAMP=959104874 channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:01 Finished backup at 03-NOV-17如果沒(méi)有指定快閃恢復(fù)區(qū)也可以用手動(dòng)指定路徑:
將快閃恢復(fù)區(qū)改為test目錄
SQL> connect/as sysdba Connected. SQL> show parameter db_recovery_file_dest; NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ db_recovery_file_dest string /data/app/oracle/recovery_area db_recovery_file_dest_size big integer 2G SQL> alter system set db_recovery_file_dest='/data/app/oracle/test'; System altered. SQL> show parameter db_recovery_file_dest; NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ db_recovery_file_dest string /data/app/oracle/test db_recovery_file_dest_size big integer 2G配置控制文件備份的磁盤(pán)類型和備份目錄,路徑以%F結(jié)尾:
RMAN> configure controlfile autobackup format for device type disk to '/data/app/oracle/test/%F'; new RMAN configuration parameters: CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK TO '/data/app/oracle/test/%F'; new RMAN configuration parameters are successfully storedRMAN脫機(jī)備份
RMAN脫機(jī)備份需要關(guān)閉數(shù)據(jù)庫(kù),啟動(dòng)數(shù)據(jù)庫(kù)到mount狀態(tài)。
[oracle@temp-test oracle]$ sqlplus /nolog SQL> connect/as sysdba Connected. SQL> shutdown immediate; Database closed. Database dismounted. ORACLE instance shut down. SQL> startup mount; ORACLE instance started. Total System Global Area 1586708480 bytes Fixed Size 2213736 bytes Variable Size 939526296 bytes Database Buffers 637534208 bytes Redo Buffers 7434240 bytes Database mounted. SQL> quit進(jìn)入RMAN,備份數(shù)據(jù):
先查看數(shù)據(jù)備份的默認(rèn)參數(shù),備份方式(copy或backupset),和備份格式(disk 或其他)
RMAN> show all; using target database control file instead of recovery catalog RMAN configuration parameters for database with db_unique_name ORCL are: CONFIGURE RETENTION POLICY TO REDUNDANCY 1; # default CONFIGURE BACKUP OPTIMIZATION ON; CONFIGURE DEFAULT DEVICE TYPE TO DISK; # default CONFIGURE CONTROLFILE AUTOBACKUP OFF; # default CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK TO '%F'; # default CONFIGURE DEVICE TYPE DISK BACKUP TYPE TO COPY PARALLELISM 1; CONFIGURE DATAFILE BACKUP COPIES FOR DEVICE TYPE DISK TO 1; # default CONFIGURE ARCHIVELOG BACKUP COPIES FOR DEVICE TYPE DISK TO 1; # default CONFIGURE MAXSETSIZE TO UNLIMITED; # default CONFIGURE ENCRYPTION FOR DATABASE OFF; # default CONFIGURE ENCRYPTION ALGORITHM 'AES128'; # default CONFIGURE COMPRESSION ALGORITHM 'BASIC' AS OF RELEASE 'DEFAULT' OPTIMIZE FOR LOAD TRUE ; # default CONFIGURE ARCHIVELOG DELETION POLICY TO NONE; # default CONFIGURE SNAPSHOT CONTROLFILE NAME TO '/data/app/oracle/product/11.2.0/dbhome_1/dbs/snapcf_orcl.f'; # default執(zhí)行備份命令使用copy方式,映像復(fù)制整個(gè)庫(kù):
RMAN> backup as copy database;如果是使用默認(rèn)的backupset模式,可以使用:
RMAN> backup as compressed backupset database;備份完成后,打開(kāi)數(shù)據(jù)庫(kù):
RMAN> sql 'alter database open'; sql statement: alter database openRMAN聯(lián)機(jī)備份整個(gè)數(shù)據(jù)庫(kù)
聯(lián)機(jī)備份必須要設(shè)置快閃恢復(fù)區(qū),快閃恢復(fù)區(qū)要足夠大,并且數(shù)據(jù)庫(kù)要置于歸檔模式。在數(shù)據(jù)庫(kù)進(jìn)行備份的同時(shí),可以進(jìn)行DML操作,可以正常讀取,新的DML操作記錄會(huì)在重做日志文件中,如果備份時(shí)間很長(zhǎng),而且在這個(gè)期間產(chǎn)生了大量的數(shù)據(jù)變化,重做日志會(huì)切換從而將這些變化的數(shù)據(jù)寫(xiě)到歸檔日志文件中。這里的歸檔日志就類似于mysql的binlog,在出現(xiàn)介質(zhì)故障的時(shí)候,使用備份和歸檔日志記錄和完成數(shù)據(jù)的全部恢復(fù)。
查看數(shù)據(jù)庫(kù)歸檔模式是否開(kāi)啟,當(dāng)前屬于關(guān)閉狀態(tài):
SQL> archive log list; Database log mode No Archive Mode Automatic archival Disabled Archive destination USE_DB_RECOVERY_FILE_DEST Oldest online log sequence 22 Current log sequence 24開(kāi)啟日志歸檔:
SQL> alter database archivelog; alter database archivelog * ERROR at line 1: ORA-01126: database must be mounted in this instance and not open in any instance日志歸檔必須在mount模式,關(guān)閉數(shù)據(jù)庫(kù)啟動(dòng)到mount模式,開(kāi)啟歸檔模式:
SQL> shutdown immediate; Database closed. Database dismounted. ORACLE instance shut down. SQL> startup mount; ORACLE instance started. Total System Global Area 1586708480 bytes Fixed Size 2213736 bytes Variable Size 1040189592 bytes Database Buffers 536870912 bytes Redo Buffers 7434240 bytes Database mounted. SQL> alter database archivelog; Database altered. SQL> alter database open; Database altered. SQL> archive log list; Database log mode Archive Mode Automatic archival Enabled Archive destination USE_DB_RECOVERY_FILE_DEST Oldest online log sequence 22 Next log sequence to archive 24 Current log sequence 24使用RMAN聯(lián)機(jī)備份數(shù)據(jù)庫(kù):
RMAN> backup as compressed backupset database plus archivelog delete all input;使用備份集格式進(jìn)行備份,并采用壓縮的方式,壓縮比例大概為5:1。備份數(shù)據(jù)文件,同時(shí)也備份歸檔日志文件,備份完成之后會(huì)將已經(jīng)備份的歸檔日志文件從存儲(chǔ)目錄中刪除,清除歸檔空間。
備份表空間:
RMAN> backup tablespace users; Starting backup at 06-NOV-17 using channel ORA_DISK_1 channel ORA_DISK_1: starting datafile copy input datafile file number=00004 name=/data/app/oracle/oradata/orcl/users01.dbf output file name=/data/app/oracle/test/ORCL/datafile/o1_mf_users_dzzxzmxv_.dbf tag=TAG20171106T134939 RECID=12 STAMP=959348980 channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:01 Finished backup at 06-NOV-17使用壓縮:
RMAN> backup as compressed backupset tablespace users;使用RMAN備份數(shù)據(jù)文件,%U表示自動(dòng)分配一個(gè)唯一的命名:
RMAN> backup as backupset datafile 1 format '/data/app/backup/datafile_1_%U';清除命令,慎用
清除舊的備份文件set格式:
RMAN> delete obsolete; RMAN> crosscheck backupset; RMAN> delete expired backupset;清楚舊的備份文件和所有備份,copy模式:
RMAN> list datafilecopy all; RMAN> delete expired backupcopy; RMAN> crosscheck datafilecopy all; RMAN> delete expired backupcopy;如果是由于快閃恢復(fù)區(qū)容量限制,可以修改快閃恢復(fù)區(qū)的路徑和容量:
SQL> alter system set db_recovery_file_dest='/data/app/oracle/test';SQL> alter system set db_recovery_file_dest_size=10g;RMAN增量備份
使用backup database時(shí),都是全庫(kù)備份,每次這樣備份很耗時(shí)也占用磁盤(pán)空間,RMAN的增量備份就能解決這些問(wèn)題。
這里有兩種備份級(jí)別,級(jí)別0備份為全庫(kù)備份,級(jí)別1的備份為增量備份,一般情況下需要對(duì)數(shù)據(jù)進(jìn)行0級(jí)別的備份之后在進(jìn)行級(jí)別1的增量備份。
RMAN> backup incremental level 0 database;級(jí)別1的差異增量備份:
RMAN> backup incremental level 1 database;對(duì)映像副本進(jìn)行增量備份
RMAN> run { 2> backup incremental level 1 for recover of copy with tag 'incr_copy_backup' database; 3> recover copy of database with tag 'incr_copy_backup'; 4> }每次執(zhí)行這條命令,就可以使用映像的方式對(duì)數(shù)據(jù)庫(kù)進(jìn)行增量備份。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
本文題目:Oracle11g使用RMAN備份數(shù)據(jù)庫(kù)-創(chuàng)新互聯(lián)
新聞來(lái)源:http://www.rwnh.cn/article30/csgpso.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、Google、營(yíng)銷型網(wǎng)站建設(shè)、虛擬主機(jī)、微信公眾號(hào)、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容