oracle冷、热备份
Oracle数据库的备份方式有冷备份和热备份两种,针对这两种备份的实施过程记录如下:
一、Oracle冷备份
概念 数据库在关闭状态下完成所有物理系统文件拷贝的过程,也称脱机备份。 适合于非归档模式(即noarchivelog模式,SCN保持一致)下,数据库处于一致性状态。 冷备份,数据库可以处于归档模式也可以处于非归档模式,最好是处于非归档模式。
步骤
- 首先在运行的库中得到数据库运行的所有的物理文件位置,然后在计划内关闭数据库(shutdown)
- 再执行拷贝物理文家到备份路径或备份设备
- 备份完成后立即启动数据库让其提供正常的服务
冷备份脚本的写法 首先应该在相关视图里查出数据库的数据文件,日志文件,控制文件,临时文件所在的位置 注意:不要直接在oradata下进行cp就行了,因为生产库里各个文件通常分布在不同的磁盘,不同的地方,所以在去视图里获得真实路径
冷备份操作
1)查看Oracle数据库的日志模式,如果是归档模式,将需要将数据库设置为noarchivelog模式(非归档模式),从而进行冷备份。
SQL> archive log list; Database log mode Archive Mode Automatic archival Enabled //Enabled表示归档模式 Archive destination USE_DB_RECOVERY_FILE_DEST Oldest online log sequence 79 Next log sequence to archive 81 Current log sequence 81
SQL> shutdown normal Database closed. Database dismounted. ORACLE instance shut down.
SQL> startup mount; ORACLE instance started. Total System Global Area 1286066176 bytes Fixed Size 2213016 bytes Variable Size 486542184 bytes Database Buffers 788529152 bytes Redo Buffers 8781824 bytes Database mounted.
SQL> alter database noarchivelog;
SQL> archive log list; Database log mode No Archive Mode Automatic archival Disabled Archive destination USE_DB_RECOVERY_FILE_DEST Oldest online log sequence 79 Current log sequence 81
SQL> alter database open;
2)查看实例和数据库的相关信息
SQL> select instance_name,version,status,archiver,database_status from v$instance; orcl 11.2.0.1.0 OPEN STOPPED ACTIVE
SQL> select dbid,name,log_mode from v$database; 1577075335 ORCL NOARCHIVELOG
3)查看数据文件及状态信息
SQL> select file_name,tablespace_name,status,online_status from dba_data_files; FILE_NAME TABLESPACE_NAME STATUS ONLINE_STATUS -------------------------------------------------------------------------------- ------------------------------ --------- ------------- /data/oracle/oradata/orcl/users01.dbf USERS AVAILABLE ONLINE /data/oracle/oradata/orcl/undotbs01.dbf UNDOTBS1 AVAILABLE ONLINE /data/oracle/oradata/orcl/sysaux01.dbf SYSAUX AVAILABLE ONLINE /data/oracle/oradata/orcl/system01.dbf SYSTEM AVAILABLE SYSTEM /data/oracle/oradata/orcl/wt_data.dbf TBS_WT_DATA AVAILABLE ONLINE /data/oracle/oradata/orcl/bdqn_data.dbf BDQN AVAILABLE ONLINE /data/oracle/oradata/orcl/bdqn_t01_data.dbf BDQN_T01 AVAILABLE ONLINE 7 rows selected
4)查看数据文件
SQL> select name from v$datafile; /data/oracle/oradata/orcl/system01.dbf /data/oracle/oradata/orcl/sysaux01.dbf /data/oracle/oradata/orcl/undotbs01.dbf /data/oracle/oradata/orcl/users01.dbf /data/oracle/oradata/orcl/wt_data.dbf /data/oracle/oradata/orcl/bdqn_data.dbf /data/oracle/oradata/orcl/bdqn_t01_data.dbf
5)查看临时文件
SQL> select name from v$tempfile; /data/oracle/oradata/orcl/temp01.dbf /data/oracle/oradata/orcl/wt_temp.dbf
6)查看日志文件
SQL> select member from v$logfile; /data/oracle/oradata/orcl/redo03.log /data/oracle/oradata/orcl/redo02.log /data/oracle/oradata/orcl/redo01.log
7)查看控制文件
SQL> select name from v$controlfile; /data/oracle/oradata/orcl/control01.ctl /data/oracle/flash_recovery_area/orcl/control02.ctl
8)创建备份目录
SQL> ho mkdir /home/oracle/coolbak
9)使用连接符生成复制文件命令
SQL> select 'ho cp ' || name || ' /home/oracle/coolbak' from v$controlfile; ho cp /data/oracle/oradata/orcl/control01.ctl /home/oracle/coolbak ho cp /data/oracle/flash_recovery_area/orcl/control02.ctl /home/oracle/coolbak
将上面的输入保存为tmpbak.sql
SQL> save /tmp/tmpbak.sql;
10)编辑tmpbak.sql,将下面的内容输入到tmpbak.sql
set feedback off set heading off set verify off set trimspool off set pagesize 0 set linesize 200 define dir = '/home/oracle/coolbak' define script = '/tmp/coolbak.sql' spool &script select 'ho cp ' || name || ' &dir' from v$controlfile union all select 'ho cp ' || name || ' &dir' from v$datafile union all select 'ho cp ' || member || ' &dir' from v$logfile union all select 'ho cp ' || name || ' &dir' from v$tempfile; create pfile = '&dir/initorcl.ora' from spfile; ho cp /data/oracle/product/11.2.0/db_1/dbs/orapworcl &dir spool off shutdown immediate start &script ho rm &script startup
执行tmpbak.sql(执行过程及其中的数据库启动在此略过)
SQL> @/tmp/tmpbak.sql; ho cp /data/oracle/oradata/orcl/control01.ctl /home/oracle/coolbak ho cp /data/oracle/flash_recovery_area/orcl/control02.ctl /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/system01.dbf /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/sysaux01.dbf /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/undotbs01.dbf /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/users01.dbf /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/wt_data.dbf /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/bdqn_data.dbf /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/bdqn_t01_data.dbf /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/redo03.log /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/redo02.log /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/redo01.log /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/temp01.dbf /home/oracle/coolbak ho cp /data/oracle/oradata/orcl/wt_temp.dbf /home/oracle/coolbak Database closed. Database dismounted. ORACLE instance shut down. ORACLE instance started. Total System Global Area 1286066176 bytes Fixed Size 2213016 bytes Variable Size 486542184 bytes Database Buffers 788529152 bytes Redo Buffers 8781824 bytes Database mounted. Database opened.
启动后查看备份的文件
SQL> ho ls /home/oracle/coolbak bdqn_data.dbf control01.ctl initorcl.ora redo01.log redo03.log system01.dbf undotbs01.dbf wt_data.dbf bdqn_t01_data.dbf control02.ctl orapworcl redo02.log sysaux01.dbf temp01.dbf users01.dbf wt_temp.dbf
冷备份总结
优点
- 冷备模式下概念易于理解,即将需要备份的文件复制到安全的位置
- 操作比较简单,不需要太多的干预
- 容易恢复到某个时间点上(只需将文件再拷贝回去)
- 能与归档方法相结合,作数据库“最新状态”的恢复。
缺点
- 备份时,数据库必须处于一致性关闭状态
- 只能提供到某一时间点的恢复
- 备份时速度比较慢,尤其是数据量大性能影响比较大
- 不能实现基于表和用户级别的数据恢复
二、Oracle热备份
概念 Oracle 热备份是指数据库处于open状态下,对数据库的数据文件、控制文件、参数文件、密码文件等进行一系列备份操作。 热备份是基于用户管理备份恢复的一种方式,也是除了RMAN备份之外较为常用的一种备份方式。 热备份时,Oracle数据库必须处于归档模式(即archivelog模式,SCN不一致)下。
热备的过程
- 冻结块头:控制SCN在备份时不发生变化
- 进行物理拷贝
- 解冻块头:让SCN可以变化(当对SCN解冻后,系统会自动更新SCN至最新的状态)
基于数据库的热备 alter database begin backup;
拷贝所有的datafile到备份目录
alter database end backup;
基于表空间的热备 alter tablespace tablespace_name begin backup;
拷贝tablespace_name表空间的数据文件到备份目录
alter tablespace tablespace_name end backup;
当alter tablespace tablespace_name begin backup时完成的任务 检查点事件发生,检查点通知DBWn将该表空间上所有的脏数据被写入到磁盘 在数据文件头部冻结当前检查点事件发生时的SCN号 所有发生变化数据块的完整镜像(修改前后)被写入到redo log中 允许该表空间内数据的正常读写
建议使用基于表空间的热备,这样将尽可能的减少对系统性能的影响
控制文件的热备 alter database backup controlfile to '<dir>' [reuse]; //控制文件的完整备份
alter database backup controlfile to trace as '<dir>'; //用于创建控制文件的语句,丢失了部分信息 控制文件发生变化情况
alter database [add |drop] logfile; alter database [add |drop] logfile member;
alter database [add |drop] logfile group; alter database [archivelog |noarchivelog];
alter database rename file; create tablespace;
alter tablespace [add | rename] datafile;
alter tablespace [read write | read only]; drop tablespace;
参数文件的热备 create pfile from spfile ; create pfile = '<dir>' from spfile;
热备份操作
1)查看Oracle数据库的日志模式,一定要确保是归档模式!
SQL> archive log list; Database log mode No Archive Mode Automatic archival Disabled//Disabled表示为非归档模式
Archive destination USE_DB_RECOVERY_FILE_DEST
Oldest online log sequence 79
Current log sequence 81
现在需要设置为归档模式
SQL> shutdown immediate Database closed. Database dismounted. ORACLE instance shut down.
SQL> startup mount ORACLE instance started. Total System Global Area 1286066176 bytes Fixed Size 2213016 bytes Variable Size 486542184 bytes Database Buffers 788529152 bytes Redo Buffers 8781824 bytes Database mounted.
SQL> alter database archivelog;
SQL> archive log list; Database log mode Archive Mode Automatic archival Enabled Archive destination USE_DB_RECOVERY_FILE_DEST Oldest online log sequence 79 Next log sequence to archive 81 Current log sequence 81
SQL> alter database open;
2)临时表空间的数据文件、日志文件不需要备份,如果设置为 备份模式,会收到报错。
查看临时表空间
SQL> select tablespace_name from dba_temp_files; TEMP TBS_WT_TEMP
查看临时表空间的数据文件
SQL> select name from v$tempfile; /data/oracle/oradata/orcl/temp01.dbf /data/oracle/oradata/orcl/wt_temp.dbf
将临时表空间置为备份模式,收到了错误的提示
SQL> alter tablespace temp begin backup; alter tablespace temp begin backup * ERROR at line 1: ORA-03217: invalid option for alter of TEMPORARY TABLESPACE
将临时表空间置为备份模式,收到了错误的提示
SQL> alter temporary tablespace temp begin backup; alter temporary tablespace temp begin backup * ERROR at line 1: ORA-00940: invalid ALTER command
3) Oracle热备份脚本
基于数据库热备的脚本
SQL> ho vi /tmp/tmphotbak.sql; //将下面的内容输入到/tmp/tmphotbak.sql脚本文件中
set feedback off set heading off set verify off set trimspool off set pagesize 0 set linesize 200 define dir = '/home/oracle/hotbak' define script = '/tmp/hotbak.sql' spool &script select 'ho cp ' ||name|| ' &dir' from v$datafile; spool off alter database begin backup; start &script alter database end backup; alter database backup controlfile to '&dir/controlbak.ctl'; create pfile = '&dir/initorcl.ora' from spfile;
执行该脚本即可对数据库进行热备
SQL> start /tmp/tmphotbak.sql;
基于表空间热备的脚本
SQL> ho vim /tmp/tmphotbak_tbs.sql //将下面的内容输入到/tmp/tmphotbak_tbs.sql脚本文件中 set feedback off set heading off set verify off set trimspool off set pagesize 0 set linesize 200 define dir = '/home/oracle/hotbaktbs' define script = '/tmp/hotbak_tbs.sql' spool &script
select 'alter tablespace '|| tablespace_name ||' begin backup ;' || chr(10)||'ho cp ' || file_name || ' &dir ' || chr(10)||'alter tablespace '|| tablespace_name || ' end backup;' from dba_data_files order by tablespace_name; spool off start &script alter database backup controlfile to '&dir/controlbak.ctl'; create pfile = '&dir/initorcl.ora' from spfile;
//chr(10) 表示换行
执行该脚本即可对数据库基于表空间进行热备
SQL> start /tmp/tmphotbak_tbs.sql;
4)备份的相关视图
SQL> desc v$backup; Name Null? Type ----------------------------------------- -------- --------------------- FILE# NUMBER STATUS VARCHAR2(18) CHANGE# NUMBER //记录备份时的SCN号 TIME DATE
状态为NOT ACTIVE ,此时没有任何数据处于备份状态
SQL> select * from v$backup; 1 NOT ACTIVE 2496029 2020-10-25 05:19:00 2 NOT ACTIVE 2496013 2020-10-25 05:18:41 3 NOT ACTIVE 2496060 2020-10-25 05:19:33 4 NOT ACTIVE 2496075 2020-10-25 05:19:48 5 NOT ACTIVE 2496049 2020-10-25 05:19:30 6 NOT ACTIVE 2495991 2020-10-25 05:18:41 7 NOT ACTIVE 2496002 2020-10-25 05:18:41
对表空间users进行热备
SQL> alter tablespace users begin backup;
对应的file# 为的处于ACTIVE状态
SQL> select * from v$backup; 1 NOT ACTIVE 2496029 2020-10-25 05:19:00 2 NOT ACTIVE 2496013 2020-10-25 05:18:41 3 NOT ACTIVE 2496060 2020-10-25 05:19:33 4 ACTIVE 2498604 2020-10-25 07:11:51 5 NOT ACTIVE 2496049 2020-10-25 05:19:30 6 NOT ACTIVE 2495991 2020-10-25 05:18:41 7 NOT ACTIVE 2496002 2020-10-25 05:18:41
备份时发生断电或意外故障的恢复
假定users表空间目前置于begin bakup模式,系统断电
SQL> alter tablespace users begin backup; Tablespace altered.
在另一个会话中强制关闭数据库
SQL> shutdown abort; ORACLE instance shut down.
启动后收到错误提示
SQL> startup ORACLE instance started. Total System Global Area 1286066176 bytes Fixed Size 2213016 bytes Variable Size 486542184 bytes Database Buffers 788529152 bytes Redo Buffers 8781824 bytes Database mounted. ORA-10873: file 4 needs to be either taken out of backup mode or media recovered ORA-01110: data file 4: '/data/oracle/oradata/orcl/users01.dbf'
查看备份视图,文件此时处于活动状态
SQL> select * from v$backup; FILE# STATUS CHANGE# TIME ---------- ------------------ ---------- ------------------- 1 UNKNOWN ERROR 2496029 2020-10-25 05:19:00 2 UNKNOWN ERROR 2496013 2020-10-25 05:18:41 3 UNKNOWN ERROR 2496060 2020-10-25 05:19:33 4 ACTIVE 2498604 2020-10-25 07:11:51 5 NOT ACTIVE 2496049 2020-10-25 05:19:30 6 NOT ACTIVE 2495991 2020-10-25 05:18:41 7 NOT ACTIVE 2496002 2020-10-25 05:18:41 7 rows selected.
使用end backup来终止备份
SQL> alter database datafile 4 end backup; --此处也可以使用recover datafile 4来完成恢复 Database altered.
SQL> select * from v$backup; FILE# STATUS CHANGE# TIME ---------- ------------------ ---------- ------------------- 1 NOT ACTIVE 2496029 2020-10-25 05:19:00 2 NOT ACTIVE 2496013 2020-10-25 05:18:41 3 NOT ACTIVE 2496060 2020-10-25 05:19:33 4 NOT ACTIVE 2498604 2020-10-25 07:11:51 5 NOT ACTIVE 2496049 2020-10-25 05:19:30 6 NOT ACTIVE 2495991 2020-10-25 05:18:41 7 NOT ACTIVE 2496002 2020-10-25 05:18:41 7 rows selected.
SQL> alter database open; Database altered.
SQL> select * from dual; D - X
-------------------------------------oracle非归档模式与归档模式备份-----------------------------------
1)不一致性备份(archivelog归档模式) 因为备份操作不可能瞬时完成,而数据文件时刻都在写,SCN时刻都在变,备份完第n个数据文件时,第n+1个数据文件的SCN有可能已经与之前的都不同了。 不一致性的备份在恢复后必须借助归档日志文件和联机重做日志,将数据库修复到一致性的状态才能打开。因此,创建不一致性备份除了备份数据库启动时必须的数据文件和控制文件之外,还需要备份归档日志文件。
2)一致性备份(noarchivelog非归档模式) 备份的数据文件和控制文件拥有相同的SCN,即一致性备份。只有数据库以shutdown immediate方式关闭。并且数据库未被置于打开状态时创建的备份才是一致性备份。
3)热备份一定是不一致性备份,即归档模式的备份 利用要创建的热备份做恢复时,有可能需要应用归档日志或联机重做日志,才能将数据库修复到一个一致性状态,因此要创建有效的热备份,要求数据库必须处于归档模式。 数据库是否处于归档模式不影响一致性备份的创建,但是对于非归档数据库而言,只有一致性备份才算是有效备份。 只有归档模式下创建的不一致性备份才能被视为有效备份,非归档模式下创建的不一致备份极有可能无法恢复,或者恢复后丢失部分数据。
4)要热备份,数据库必须处于归档模式。冷备份,数据库可以处于归档模式也可以处于非归档模式
浙公网安备 33010602011771号