Oracle 热备份

=======================

-- Oracle 热备份

--=======================

Oracle 热备份是指数据库处于open状态下,对数据库的数据文件、控制文件、参数文件、密码文件等进行一系列备份操作。

热备是基于用户管理备份恢复的一种方式,也是除了RMAN备份之外较为常用的一种备份方式。

一、热备的过程

冻结块头-->控制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

更多关于控制文件请参考:Oracle 控制文件

五、参数文件的热备

create pfile from spfile ;

create pfile = ‘<dir>‘ from spfile;

更多关于参数文件请参考:Oracle 参数文件

六、临时表空间的数据文件、日志文件不需要备份

--查看临时表空间

SQL> select tablespace_name from dba_temp_files;

TABLESPACE_NAME

------------------------------

TEMP

--查看临时表空间的数据文件

SQL> select name from v$tempfile;

NAME

------------------------------------------------------

/u01/app/oracle/oradata/orcl/temp01.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

七、热备脚本

1.基于数据库热备的脚本

SQL> ho cat /tmp/tmphotbak.sql;

set feedback off

set heading off

set verify off

set trimspool off

set pagesize 0

set linesize 200

define dir = ‘/u01/app/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;  --执行该脚本即可对数据库进行热备

2.基于表空间热备的脚本

SQL> ho cat /tmp/tmphotbak_tb.sql

set feedback off

set heading off

set verify off

set trimspool off

set pagesize 0

set linesize 200

define dir = ‘/u01/app/oracle/hotbak‘

define script = ‘/tmp/hotbak_tb.sql‘

ho rm &script

ho rm &dir/*

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;

SQL> start /tmp/tmphotbak.sql;  --执行该脚本即可对数据库基于表空间进行热备

八、备份的相关视图

v$backup

SQL> desc v$backup;

Name                                      Null?    Type

----------------------------------------- -------- ---------------------

FILE#                                              NUMBER

STATUS                                             VARCHAR2(18)

CHANGE#                                            NUMBER   --记录备份时的SCN号

TIME                                               DATE

SQL> select * from v$backup;   --状态为NOT ACTIVE ,此时没有任何数据处于备份状态

FILE# STATUS                CHANGE# TIME

---------- ------------------ ---------- ---------

1 NOT ACTIVE            1006747 16-AUG-10

2 NOT ACTIVE            1006793 16-AUG-10

3 NOT ACTIVE            1006729 16-AUG-10

4 NOT ACTIVE            1006807 16-AUG-10

5 NOT ACTIVE            1006717 16-AUG-10

SQL> alter tablespace users begin backup;  --对表空间users进行热备

Tablespace altered.

SQL> select * from v$backup;   --对应的file# 为的处于ACTIVE状态

FILE# STATUS                CHANGE# TIME

---------- ------------------ ---------- ---------

1 NOT ACTIVE            1006747 16-AUG-10

2 NOT ACTIVE            1006793 16-AUG-10

3 NOT ACTIVE            1006729 16-AUG-10

4 ACTIVE                1006852 16-AUG-10

5 NOT ACTIVE            1006717 16-AUG-10

--备份时发生断电或意外故障的恢复

--假定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  469762048 bytes

Fixed Size                  1220048 bytes

Variable Size              92275248 bytes

Database Buffers          373293056 bytes

Redo Buffers                2973696 bytes

Database mounted.

ORA-01113: file 4 needs media recovery

ORA-01110: data file 4: ‘/u01/app/oracle/oradata/orcl/users01.dbf‘

--查看备份视图,文件此时处于活动状态

SQL> select * from v$backup;

FILE# STATUS                CHANGE# TIME

---------- ------------------ ---------- ---------

1 NOT ACTIVE            1006958 16-AUG-10

2 NOT ACTIVE            1006983 16-AUG-10

3 NOT ACTIVE            1006943 16-AUG-10

4 ACTIVE                1007072 16-AUG-10

5 NOT ACTIVE            1006931 16-AUG-10

--使用end backup来终止备份

SQL> alter database datafile 4 end backup;   --此处也可以使用recover datafile 4来完成恢复

Database altered.

SQL> alter database open;

Database altered.

SQL> select * from dual;

D

-

X

有关Oracle的冷备份,请参考:Oracle 冷备份

转:http://blog.csdn.net/leshami/article/details/5816012

时间: 2024-10-12 22:23:58

Oracle 热备份的相关文章

oracle热备份与冷备份的对比

一. 冷备份 冷备份发生在数据库已经正常关闭的情况下,当正常关闭时会提供给我们一个完整的数据库.冷备份时将要害性文件拷贝到另外的位置的一种说法.对于备份Oracle信息而言,冷备份时最快和最安全的方法.冷备份的优点是: 1. 是非常快速的备份方法(只需拷文件) 2. 轻易归档(简单拷贝即可) 3. 轻易恢复到某个时间点上(只需将文件再拷贝回去) 4. 能与归档方法相结合,做数据库“最佳状态”的恢复. 5. 低度维护,高度安全. 但冷备份也有如下不足: 1. 单独使用时,只能提供到“某一时间点上”

Oracle热备份

如果系统是一个7X24小时的运行的数据库,冷备份是不现实的,热备份是在数据库运行的情况下,采用archivelog mode 方式备份数据库的方法. 热备份的优缺点如下: 优点:a.可在表空间或数据库文件级备份.备份时间短 b.可达到秒级恢复(恢复到某一时间点上) c.可对几乎所有数据库实体做恢复 d.恢复是快速的,在大多数情况下在数据库仍工作时恢复 f.备份的数据库仍可用 缺点:a.难以维护,所以要特别仔细小心,不允许以失败而告终. b.若备份不成功,所得结果不可用于时间点的恢复 c.不能出错

浅一下oracle热备份users表空间

数据库要运行在归档模式下:archive log listshutdown immediatestartup mountalter database archivelog;alter database open;archive log list 热备份users表空间: (1)实验环境相关信息查看 创建备份路径 mkdir -p /home/oracle/hotbk/ 这里为了测试更改归档文件的路径 mkdir /home/oracle/arc_orcl_dest1/ alter system 

Oracle 数据库日常巡检

Oracle 数据库日常巡检 阅读目录 1. 检查数据库基本状况 2. 检查Oracle相关资源的使用情况 3. 检查Oracle数据库备份结果 4. 检查Oracle数据库性能 5. 检查数据库cpu.I/O.内存性能 6. 检查数据库安全性 7. 其他检查 回到顶部 1. 检查数据库基本状况 包含:检查Oracle实例状态,检查Oracle服务进程,检查Oracle监听进程,共三个部分. 1.1. 检查Oracle实例状态 select instance_name,host_name,sta

Oracle 闪回特性(FLASHBACK DATABASE)

--===================================== -- Oracle 闪回特性(FLASHBACK DATABASE) --===================================== 闪回技术通常用于快速简单恢复数据库中出现的认为误操作等逻辑错误,从闪回的方式可以分为基于数据库级别闪回.表级别闪回.事务 级别闪回,根据闪回对数据的影响程度又可以分为闪回恢复,闪回查询.闪回恢复将修改数据,闪回点之后的数据将全部丢失.而闪回查询则可 以查询数据被DML的

oracle数据库备份

Oracle数据库的备份方法 1.引言 Oracle数据库的备份方法很多,无论使用那种备份方法,备份的目的都是为了在出现故障后能够以尽可能小的时间和代价恢复系统.比如使用export实 用程序导出数据库对象.使用Oracle备份数据库.使用Oracle对称复制.使用Oracle并行服务器.使用Oracle冷备份.使用Oracle 热备份等各种备份方法都有其优缺点.适用的场合和相应的软硬件要求.本文主要就用export实用程序导出数据库对象.Oracle冷备份.Oracle 热备份这三种最基本的备

使用yum快速部署Oracle安装环境(11g)

基于Linux安装过Oracle的童鞋们都应该清楚,安装Oracle的确是一件比较费时费力的差事,因为仅仅是前期的rpm包,内核参数,创建用户等等这些个步骤都让那些新手不免眼花缭乱,一不留神,就导致最终的安装过程中报错而不得不从头来过.现在基于Oracle Linux,Oracle仅仅需要通过安装oracle-rdbms-server-11gR2-preinstall RPM包即可全部搞定其余未安装的RPM包,解决之间的依赖关系,配置内核参数等等.客官,正在基于Oracle Linux 安装Or

ORACLE 热备begin backup / end backup

执行begin backup之后,oracle会把将要备份的数据文件都标记为hot-backup-in-progress,锁定所要备份的datafile header的scn,例如此时scn=100,同时redolog中会记住这个scn,其他数据文件正常使用,scn会继续增长.之后在备份所要备份的数据文件过程中,数据文件是允许写入和checkpoint,而且可能不止一次checkpoint,而这个过程中的所有操作和checkpoint也会正常记录到redolog与archivelog中. ora

Oracle Linux 6.3下安装Oracle 11g R2(11.2.0.3)

本文主要描述了在Oracle Linux 6.3下安装Oracle 11gR2(11.2.0.3).从Oracle 11g开始,Oracle官方网站不再提供其Patch的下载链接,需要使用Meatlink账户才可以进行下载.童鞋们不要着急,没有Metalink账户的也可以自己百度一下,网上有很多下载链接,迅雷就可以搞定了.Oracle 11.2.0.3整合为7个zip压缩包,如果仅仅是安装Oracle Database,下载1至2.zip包即可.下面是其安装步骤. 一.准备安装环境1.安装rpm