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)要热备份,数据库必须处于归档模式。冷备份,数据库可以处于归档模式也可以处于非归档模式

posted on 2020-10-25 19:16  wtsgtc  阅读(816)  评论(0)    收藏  举报

导航