第9章Oracle数据库备份与恢复_第1页
第9章Oracle数据库备份与恢复_第2页
第9章Oracle数据库备份与恢复_第3页
第9章Oracle数据库备份与恢复_第4页
第9章Oracle数据库备份与恢复_第5页
已阅读5页,还剩108页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第九章第九章 Oracle数据库备份与恢复数据库备份与恢复本章内容本章内容 9.1 数据库常见故障类型 9.2 数据库保护机制 9.3 数据库逻辑备份与恢复 9.4 脱机备份(冷备份) 9.5 联机备份(热备份) 9.6 使用OMS工具的备份与恢复向导 9.7 数据库恢复 DBA的主要职责之一是备份数据库和在数据库发生故障时及时、高效、安全地恢复数据库。 备份方法 冷备份 热备份 逻辑备份(Export/Import) 恢复方法 完全恢复 不完全恢复 RMAN备份恢复等方式9.1 数据库常见故障类型 系统崩溃或服务器崩溃 用户错误、冲突或者磁盘失效导致的文件丢失 SQL语句失败 网络故障 场地

2、灾难9.2 数据库保护机制 Oracle数据库保护机制:数据库备份和事务日志。 Oracle数据库事务日志数据库备份l 一般来说,数据库备份可以分为物理备份和逻辑备份l 物理备份可分为脱机备份和联机备份。脱机备份又称为冷备份,只能在数据库关闭后进行备份;联机备份又称为热备份,数据库没有关闭,用户还可以使用。l 逻辑备份是使用Export实用程序备份,当数据库出现故障,可以使用Oracle的Import实用程序恢复数据库数据库备份 数据库的事务日志(Transaction Log)是一组操作系统文件,它记录了提交事务所做的数据库修改。 日志主要是保护数据库,在数据库出现故障时执行恢复。 为了防止

3、日志本身的故障,Oracle允许在不同的物理磁盘上维护两个或多个日志的副本。事务日志(1)正常工作时,每天晚上备份数据库,包含所有数据文件。(2)某一天,包含数据库的某个数据文件的磁盘坏了,因此一部分数据不可用(做了磁盘容错的情况例外),因此需要执行数据库恢复。(3)把有问题的磁盘更换为新的磁盘。(4)将最近的数据库备份存入新的磁盘中以恢复丢失的数据文件,但是,恢复的数据文件丢失了备份发生后所提交的事务工作。(5)最后,执行数据库恢复工作。在恢复过程中,Oracle读取事务日志,把过去提交的事务工作重做,使数据库文件成为当前文件。(6)数据库恢复后,打开数据,供应用程序使用。举例,磁盘失效后如

4、何保护和恢复数据库 。 归档方式(ARCHIVELOG),归档方式的目的是当数据库发生故障时最大限度恢复数据库,可以保证不丢失任何已提交的数据。 不归档方式(NOARCHIVELOG),只能恢复数据库到最近的回收点(冷备份或是逻辑备份)。 ORACLE数据库两种运行方式9.3 数据库逻辑备份与恢复 数据库逻辑备份:读一个数据库记录集,并以Oracle提供的内部格式写入一个二进制文件中。这些记录的读出与其物理位置无关。 在Oracle中,Export实用程序执行逻辑备份。 使用Oracle的Import实用程序执行数据库恢复。 当用户导入导出时,有相应的权限要求。 在OEM中,当用户连接到Ora

5、cle Management Server时,可以使用图形界面执行数据库的导入和导出。9.3.1 导出 Oracle的实用程序Export 用来读取一个数据库,并把输入写入一个称为导出转储文件(export dump file)的二进制文件。 EXP USERID=username/password PARAMETER=(value1,value2,.) 可以通过如下命令来显示参数 EXP HELP=Y 导出方式:Full方式、User方式和Table方式。 完全数据库导出 exp system/manager full=Y constraints=Y file=f:backuptest.dm

6、p 导出用户表 exp user1/password tables=employees file=f:backuptest.dmp exp user1/password tables=(employees,jobs) file=f:backuptest.dmp 导出用户模式 exp user1/password owner=user1 file=test.dmp Oracle的Import实用程序执行导入,来恢复数据库。Import实用程序读取由Export创建的二进制导出转储文件并执行其中的命令 。 IMP USERID=username/password PARAMETER=(value1

7、,value2,.) 可以通过如下命令来显示参数 IMP HELP=Y 导出的数据可以导入到不同的数据库中,甚至可以导入到与生成导出转储文件不同的模式中;可以导入全部或部分已导出的数据 。9.3.2 导入 导入用户自身所拥有的表IMP system/ora456 tables=student file=f:backuptest.dmpIMP system/ora456 tables=(student, course) file=f:backuptest.dmp 导入用户模式 imp system/manager FROMUSER=scott TOUSER=system tables=dept

8、file=f:backuptest.dmp 案例1,导出数据库表,用户误操作删除表,执行导入表,恢复数据库 (1)TEST2数据库(System用户,口令为ora456),导出表student9.3.3 逻辑备份案例 (2)删除表student中的数据,或者将整个表删除,数据已经不存在,或者表被删除 (3)导入表student,恢复数据库 (4)查询表和数据,验证导入是否成功 案例2,导入其他方案的表。将Scott的表dept导入System (1)System下没有Scott的表dept,注意,这不同与查询时使用scott.dept (2)在system下,导出Scott的表dept,导出文

9、件test2.dmp (3)将Scott的表dept导入到System中(4)再次执行步骤(1)中的查询,验证导入成功 9.4 脱机备份(冷备份) 脱机备份是最简单的一种数据库备份方式,在数据库关闭后进行备份,用户不能访问数据库,是一种完全备份。 脱机备份一般需要备份如下文件: (1)所有数据文件 (2)所有控制文件 (3)所有联机重做日志 (4)init.ora文件脱机备份步骤(1)以DBA或特权用户登录,对于需要的备份文件,用户也可通过下列SQL语句来了解数据文件、重演日志文件及控制文件的相应位置及名称。SELECT * FROM V$LOGFILE;SELECT * FROM V$DBF

10、ILE;SELECT * FROM V$CONTROLFILE;(2)关闭数据库SHUTDOWN NORMAL;或者执行SHUTDOWN IMMEDIATE; (3)复制数据文件 用拷贝命令备份全部的数据文件、重做日志文件、控制文件、初始化参数文件等。 简单的处理方法是将数据库所在路径下的文件全部复制备份。在下面实验案例中所用数据库TEST2的目录是:f:oracleoradatatest2(4)重新启动数据库STARTUP; 脱机备份的优点: 只需要拷贝文件,速度比较快。 将文件拷贝回去,数据库就可以恢复到某个时间点。 若结合数据库归档模式可以很好地恢复数据库。 维护量相对较少,但安全性相对

11、较高。 脱机备份的缺点: 脱机备份时,数据库必须关闭。 单独使用脱机备份,数据库只能基于某一时间点恢复。 若磁盘空间有限,使用磁带等外设时速度较慢。 脱机备份不能按表或用户恢复。 案例,脱机备份与不完全数据库恢复 脱机备份数据库相应文件,由于误操作,删除了users表空间对象STUDENT表,将备份的数据文件复制到原来的位置,恢复数据库到执行误操作前的状态。以SYSDBA登录。数据字典DBA_TABLES可以查询表所在的表空间。 (1)对象STUDENT,有两条记录 (2)脱机备份shutdown immediate;备份数据文件user01.dbf,控制文件,重做日志文件,或者直接将f:or

12、acleoradatatest2目录下的文件全部备份。 备份结束重启数据库startup; (3)对象student增加一条记录insert into system.student values(1003,liming,20,CS); (4)模拟误操作,删除了表STUDENTdrop table system.student;commit; (5)查询对象STUDENT,返回错误信息 (6)关闭数据库shutdown immediate; (7)复制原先备份的数据文件,控制文件,重做日志等到原来目录下,f:oracleoradatatest2 (8)startup mount; (9)执行基于

13、取消的恢复,recover database until cancel (10)以RESETLOGS方式打开数据库 (11)查询对象STUDENT,只有脱机备份的两条记录,备份后增加的记录没有恢复9.5 联机备份(热备份) 联机备份是在数据库运行时进行的备份,用户仍然可以访问数据库,一些关键行业的数据必须运行在7*24模式下,并不适合执行脱机备份,必须使用联机备份。 联机备份要求数据库运行在归档(archivelog)模式下,该方式下,联机重做日志被归档,数据库中所有事务的完整记录由Oracle以循环方式写入联机重做日志文件 。 联机备份一般备份数据文件、控制文件和日志文件。 (1)备份所有数

14、据文件 (2)备份所有归档的重做日志文件 (3)备份一个控制文件 (4)检查发生故障的数据文件,恢复数据文件联机备份的优点:可在表空间或数据文件级备份,备份时间短。备份时数据库仍可使用。可达到秒级恢复(恢复到某一时间点上)。可对几乎所有数据库实体作恢复。恢复快速,大多数情况下恢复不需要关闭数据库。 联机备份的缺点: 不能出错,否则后果严重。 若联机备份不成功,所得结果不可用于时间点的恢复。 因难于维护,所以要特别小心,不允许“以失败而告终”。 案例,联机备份与完全数据库恢复 在表空间APPL_DATA上建立对象COURSE,首先执行联机备份,在COURSE表上加入记录,然后删除数据文件APPL

15、_DATA,最后执行恢复,数据文件重新联机,验证恢复成功。 (1)在归档模式下,在表空间APPL_DATA上建立表COURSE,并插入两条记录 (2)切换日志,查看v$log确认当前日志已经更改alter system switch logfile; (3)备份控制文件(在本案例中可以不做)alter database backup controlfile to f:backupbackup.ctl; (4)备份数据文件先将表空间APPL_DATA设置为备份模式alter tablespace appl_data begin backup;拷贝表空间的数据文件APPL_DATA.ORA,其他数

16、据文件不变。copy f:oracleoradatatest2appl_data.ora f:backupappl_data.ora将表空间APPL_DATA设置为正常模式alter tablespace appl_data end backup; (5)在COURSE表上添加记录insert into course values(30, database, 20, 4); (6)使表空间脱机,删除数据文件APPL_DATA.ORA alter tablespace appl_data offline;del f:oracleoradatatest2appl_data.ora (7)将表空间联

17、机,出现错误,提示恢复数据文件 (8)将备份的数据文件复制到原来所在位置,执行数据文件恢复。copy f:backupappl_data.ora f:oracleoradatatest2appl_data.ora 然后,执行数据文件恢复命令,本例中文件号为11recover datafile 11; (9)联机表空间 (10)查询对象COURSE表,确认联机备份恢复成功,联机备份前的数据和备份后新增加的数据都存在9.6 使用OMS工具的备份与恢复向导9.6.1 Oracle管理服务器的配置 使用备份向导实现联机备份与恢复,需要登录到Oracle管理服务器OMS。 需要先配置Oracle管理服务

18、器,选择【开始】-【程序】-【OraHome90】-【Configuration and Migration Tools】-【Enterprise Manager Configuration Assistant】 ,进入OMS的配置步骤。 进入OMS后,为了保证备份向导的正确执行,应做如下工作:(1)检查SYS和SYSTEM用户权限,SYSTEM用户在独立模式下具有SYSDBA权限和SYSOPER权限,在管理服务器模式下不具备SYSDBA权限,不能启动和关闭数据库,需要人工授予SYSOPER和SYSDBA权限,同时应给SYSTEM用户添加角色EXP_FULL_DATABASE和角色 IMP_F

19、ULL_DATABASE,确保数据库备份与恢复操作正常。SYS用户无论是独立模式还是管理服务器模式都有SYSOPER和SYSDBA权限。 (2)检查操作系统用户是否作为批处理作业登录。选择【开始】-【程序】-【管理工具】-【本地安全策略】,选择用户权限分配,选择作为批处理作业登录,双击打开后添加Administrator用户。 (3)检查节点和数据库的首选证明,设置节点的首先身份证明中的用户名为Administrator,并输入口令。设置数据库的首先身份证明的用户为SYS,输入口令,选择以SYSDBA角色。 第一次登录管理服务器OMS,管理员为SYSMAN,缺省口令为OEM_TEMP 初次登录

20、,系统将提示更改SYSMAN口令。如果系统提示连接验证错误VTK-1000,查看【管理工具】-【服务】-【OracleOraHome90ManagementServer】是否启动,若没有启动,应手动启动该服务。9.6.2 使用OMS备份向导 1预定义备份策略 首先选择预定义备份策略,单击下一步按钮,出现“备份频率”对话框 2自定义备份策略 打开备份向导,策略选择自定义备份策略,出现“备份选择”对话框。 为了较快地看到备份结果,我们选择备份表空间,这是数据库子集的备份。查看“作业”节点,在活动项中可以看到备份0053已经启动,等待一会儿切换到历史记录,可以看到备份0053已经执行完成。 选择备份

21、0053,右键选择“查看作业”,可以显示备份的详细信息。 选择状态已完成,单击“显示输出”按钮,得到执行备份的脚本代码。 向导恢复可以选择 数据库恢复 表空间恢复 数据文件恢复三种 恢复向导判别目标数据库的状态(归档日志,无归档日志,已装载没有打开,装载并打开)来禁止选项。 9.6.3 使用OMS恢复向导恢复整个数据库时,将恢复属于该数据库的所有数据文件,要求数据库只处于装载状态,即NOMOUNT方式启动。表空间恢复将恢复数据库的一个子集合。对选定的表空间进行恢复,一般要求数据库运行在归档模式下。数据文件恢复将恢复单个数据文件,数据文件恢复不如表空间恢复那样常用,一般要求数据库运行在归档模式下

22、 登录到管理服务器,选择数据库,选择【工具】-【数据库向导】-【备份管理】-【恢复】,起用恢复向导。如果不能启动OMS,应查看【管理工具】-【服务】-【OracleOraHome90ManagementServer】是否启动,如果没有启动,先启动该服务。 若要查看执行情况,可以在OMS的节点“作业”中,选择历史记录确认备份和恢复情况。 9.7 数据库恢复 恢复可以分为完全恢复和不完全恢复 完全数据库恢复是恢复到故障发生前的状态,所有已经提交的操作都进行恢复,确保数据库不丢失任何数据,完全恢复只用于归档模式。 不完全数据库恢复是将数据库恢复到备份点与介质失败点之间某个时刻的状态,并不是恢复所有提

23、交的操作,不完全恢复可能丢失部分数据。 任何类型的恢复包括两个阶段:前滚阶段和回滚(回退)阶段。 前滚阶段 在前滚恢复阶段(roll-forward recovery),恢复管理器应用必要的事务日志组“重做”(REDO)所有提交的不在数据库数据文件中的事务 。 回滚阶段 在前滚恢复后,Oracle必须执行回滚恢复(roll-back recovery)。 由于一些未完成的事务对数据库的修改信息已经提交到数据库,为保证数据库的一致性,需要清除这些事务对数据库的修改,数据库应执行回滚操作(UNDO),强制撤销这些未完成事务。 前滚和回滚的执行除了管理员或应用程序调用外,执行前滚操纵还是回滚操作与检

24、查点的出现相关 12345检查点检查点系统故障系统故障上一检查点上一检查点无无前滚前滚回滚回滚前滚前滚回滚回滚故障时需要的动作故障时需要的动作 数据库备份 日志 回退段 控制文件9.7.1 恢复数据库所使用的结构 当数据库实例意外地(如掉电、后台进程故障等)或预料地(发出shutdown abort语句)终止时出现实例故障,此时需要实例恢复。 实例恢复将数据库恢复到故障前的事务一致状态。 如果联机备份时出现实例故障,则需要介质恢复。 在其它情况下,Oracle在下次数据库起动时(对新实例装配和打开),自动地执行实例恢复。9.7.2 实例故障的一致性恢复恢复步骤处理(1)为恢复数据文件中没有记录

25、的数据,进行前滚。数据记录在联机日志中,包括对回滚段的内容恢复。(2)回滚未提交的事务。(3)释放在故障时正在处理事务所持有的资源。(4)解决在故障时执行的任何悬而未决的分布事务。 电源失效和软件问题是引起一台Oracle数据库服务器出现意外崩溃的常见原因。 当系统崩溃时,数据库服务器没有完全关闭。 在系统崩溃期间,Oracle没有时间执行数据库检查点以确保缓存中被修改的数据块安全地写回到数据文件中。 系统崩溃不会永久损坏任何一个数据库的数据文件。 9.7.3 崩溃恢复 介质故障是当一个文件、一个文件的部分、磁盘不能读或不能写时出现的故障,介质故障后,必须执行一个介质恢复操作。在一个典型的介质

26、恢复期间,必须完成以下几步操作: (1)修理所有的硬件问题 (2)重建丢失的数据文件 (3)使用必要的事务日志组,完成恢复操作 (4)执行一个适当的介质恢复9.7.4 介质恢复 完全恢复是一种恢复所有提交事务的操作,恢复全部丢失的修改。 完全恢复包括数据库恢复、表空间恢复和数据文件恢复。9.7.5 完全恢复 数据库恢复 数据库恢复是恢复数据库中所有丢失工作的最简单的方法,用于恢复数据库的全部数据文件,恢复管理器识别受损的数据文件并且使用恢复目录、可用的数据文件备份集和事务日志来执行自动恢复。执行数据库恢复,应当关闭数据库,使其不可使用。 表空间恢复 当一个数据库的部分被损坏,并且需要高可用性时

27、,可以考虑使用表空间恢复。对特定表空间的全部数据文件中丢失的工作进行恢复。但是,如果系统表空间损坏了,不能执行系统表空间的恢复工作。 数据文件恢复 当一个单独的数据文件损坏,可以考虑数据文件恢复,可用于一个特定数据文件中丢失的工作。在数据库打开,并且受损的数据文件所在的表空间脱机后,利用恢复管理器来执行数据文件的恢复。 在一些情况下,可以执行不完全恢复,使用事务日志的重做项恢复提交事务的一部分工作,重构受损的数据库,使其恢复介质故障前或用户出错之前的一个事务一致性状态。 Oracle和恢复管理器支持三种不同类型的不完全恢复 基于时间(TIME)的恢复 基于修改(SCN)的恢复 基于取消的恢复。 9.7.6

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论