oracle联机数据库备份详解

所属分类: 数据库 / oracle 阅读数: 69
收藏 0 赞 0 分享

尽管很多时候数据库系统运行缓慢,但对数据库数据的丢失而言,显然后者损失的代价是不言而喻的。因此DBA至少在保证数据不丢失的情况下来提高系统的性能是最起码的要求
联机数据库备份
一旦数据库运行在archivelog方式,在打开并对用户可用时就可以进行备份。这一特性允许连续运转的数据库可以归档并能保证其恢复性。联机热备份应该安排在用户活动最少的时间段进行。
联机热备份包括三个过程,即逐个表空间地备份数据文件、备份归档重做日志文件和备份控制文件。
1. 逐个表空间地备份数据文件
该过程又可以分为四个步骤,即查询表空间包括哪些数据文件、设置表空间为备份状态、备份表空间的数据文件、将表空间恢复到正常状态。
(1) 查询表空间包括哪些数据文件
执行命令select tablespace_name,file_name from dba_data_files可以获得系统中所有数据文件以及其归属的表空间。
(2) 设置表空间为备份状态
执行命令alter tablespace tablespace_name begin backup将表空间tablespace_name设置为备份状态。
(3) 备份表空间的数据文件
执行操作系统的文件备份命令将表空间的数据文件备份。
(4) 将表空间恢复到正常状态
执行命令alter tablespace tablespace_name end backup将表空间tablespace_name恢复到正常状态。
2. 备份归档重做日志文件
该过程又可以分为三个步骤,即暂停归档进程ARCH、备份归档重做日志文件。
(1) 暂停归档进程ARCH
执行命令archive log stop暂停归档进程ARCH。
(2) 记录归档目标目录中已归档日志文件的列表
可以查询V$LOG动态字典视图。如果日志已完全归档, V$LOG的archived列将含有YES值。可以从V$LOG选择最高的归档日志(使用sequence#列)并将其用作备份文件清单的基础。例如,如果V$LOG表明sequence#2334是最后一个被归档的日志文件,就可以成功地备份归档重做日志目标目录中所有序号在2334以下的文件。如果试图备份2335,可以在操作系统级成功备份,但由于这个文件还没有完全归档,这个备份可能只写入一半,因而在恢复操作期间不可能有用。
(3) 重新启动归档进程ARCH
执行命令archive log start启动归档进程ARCH。
(4) 备份归档重做日志文件
执行操作系统的文件备份命令备份归档重作日志文件。
(5) 从归档目标目录中删除已经备份的归档日志文件
3. 备份控制文件
执行命令alter database backup controlfile to destinantion/control.bak进行在线备份控制文件。也可以执行alter database backup controlfile to trace将create controlfile的命令写入到数据库的跟踪文件中

联机热备份失败后,如何打开数据库
因为表空间还处在热备份状态。
  
模拟现象及解决方法:
  
先将数据库设置为归档模式

复制代码 代码如下:

C:>svrmgrl
svrmgrl>connect internal
svrmgrl>alter tablespace 表空间名 begin backup;
--表空间热备模式没结束就强行关闭数据库,造成错误
svrmgrl>shutdown abort
svrmgrl>startup mount
--将此表空间的数据文件在没打开数据库时置成end backup模式
svrmgrl>alter database datafile '表空间的数据文件名' end backup;
--或执行表空间介质恢复
svrmgrl>recover tablespace 表空间名;
svrmgrl>alter database open;

更多精彩内容其他人还在看

VS2015连接Oracle数据库的详细步骤

这篇文章主要介绍了VS2015连接Oracle数据库的详细步骤,需要的朋友可以参考下
收藏 0 赞 0 分享

常用的Oracle doc命令(收藏)

这篇文章主要介绍了常用的Oracle doc命令(收藏)的相关资料,非常不错,具有参考借鉴价值,需要的朋友参考下吧
收藏 0 赞 0 分享

ORACLE SQL语句优化技术要点解析

这篇文章主要介绍了ORACLE SQL语句优化技术的相关内容,小编觉得挺不错的,在这里分享给大家,需要的朋友可以参考下。
收藏 0 赞 0 分享

ORACLE多条件统计查询的简单方法

这篇文章主要介绍了ORACLE多条件统计查询的简单方法,具有一定参考价值。这里给大家分享下,希望对大家有所帮助。
收藏 0 赞 0 分享

ORACLE批量导入图片到BLOB字段代码示例

这篇文章主要介绍了ORACLE批量导入图片到BLOB字段代码示例,此代码示例是文章作者的项目源码,具有一定参考价值,需要的朋友可以了解下。
收藏 0 赞 0 分享

PLSQL Developer登录的默认密码介绍

这篇文章主要介绍了PLSQL Developer登录的默认密码介绍,具有一定参考价值,需要的朋友可以了解下。
收藏 0 赞 0 分享

Oracle数据行拆分多行方法示例

oracle数据库使用过程中,怎样将一行或者多行数据分割成需要的多行数据,本文我们就来看看具体方法,需要的朋友可以参考。
收藏 0 赞 0 分享

Oracle表空间不足的两种解决办法

这篇文章主要介绍了Oracle表空间不足的两种解决办法,需要的朋友可以参考下
收藏 0 赞 0 分享

巧妙解决Oracle NClob读写问题(经验分享)

下面小编就为大家带来一篇巧妙解决Oracle NClob读写问题(经验分享)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

oracle执行update语句时卡住问题分析及解决办法

这篇文章主要介绍了oracle执行update语句时卡住问题分析及解决办法,涉及记录锁等相关知识,具有一定参考价值,需要的朋友可以了解。
收藏 0 赞 0 分享
查看更多