|
1 引言
随着计算机信息化的普及和大量数据的电子化,数据安全显得尤为重要。一旦造成数据丢失,将会付出巨大的工作量去弥补数据,也可能因此造成不可挽回的损失。因此对从事数据库管理的DBA 来说,做好数据的备份与恢复是一项很重要的工作,本文专门针对Oracle数据库的备份与恢复进行探讨。
Oracle数据库有四种常用的备份方法,它们分别是导出/导入(EXP/IMP)、热备份、冷备份、rman备份。
2 导出、导入(Export、Import)
利用Export可将数据从数据库中提取出来,利用Import则可将提取出来的数据送回到Oracle数据库中去,这是人们最常用,也是比较可靠的一种备份恢复方法。在数据库的版本升级时一般采用这种方法。Oracle支持三种方式类型的输出,下面举例说明(jnth是用户名,thpassword是用户密码, oracle是数据库服务命名, yxgl_a、yxgl_b, yxgl_c是表名):
2.1 表方式(T方式),将指定表的数据导出
备份某个用户模式下指定的对象(表)。业务数据库通常采用这种备份方式,若备份到本地文件,使用如下命令:
exp jnth/thpassword@oracle rows=y indexes=n compress=n buffer=50000000 file=080813.dmp log=080813.log tables= yxgl_a,yxgl_b,yxgl_c
2.2 用户方式(U方式),将指定用户的所有对象及数据导出
备份某个用户模式下的所有对象。业务数据库通常采用这种备份方式,若备份到本地文件,使用如下命令:
exp jnth/thpassword@oracle owner=jnth rows=y indexes=n compress=n buffer=50000000 file=080813.dmp log=080813.log
2.3 全库方式(Full方式),将数据库中的所有对象导出
备份完整的数据库,备份命令为:
exp system/manager@oracle rows=y indexes=n compress=n buffer=50000000 full=y file=080813.dmp log=080813.log
数据导入(Import)的过程是数据导出(Export)的逆过程,分别将数据文件导入数据库和将数据库数据导出到数据文件。
2.4 恢复备份数据中的指定表
若从本地文件恢复,使用如下命令:
imp jnth/thpassword@oracle fromuser=jnth touser=jnth rows=y indexes=n commit=y buffer=50000000 ignore=n file=080813.dmp log=080813.log tables=yxgl_a,yxgl_b,yxgl_c
2.5 按照用户模式备份的数据进行恢复
A. 恢复备份数据的全部内容
若从本地文件恢复,使用如下命令:
imp jnth/thpassword@oracle fromuser=jnth touser=jnth rows=y indexes=n commit=y buffer=50000000 ignore=n file=080813.dmp log=080813.log
B. 恢复备份数据中的指定表
若从本地文件恢复,使用如下命令:
imp jnth/thpassword@oracle fromuser=jnth touser=jnth rows=y indexes=n commit=y buffer=50000000 ignore=n file=080813.dmp log=080813.log tables=yxgl_a,yxgl_b,yxgl_c
2.6 如果备份方式为完全模式,采用下列恢复方法
若从本地文件恢复,使用如下命令:
imp system/manager@oracle rows=y indexes=n commit=y buffer=50000000 ignore=y full=y file=080813.dmp log=080813.log
导出、导入(Export、Import)的优点:
●简单易行;
●可靠性高;
●不影响数据库的正常运行。
缺点:
●只能提供到“某一时间点上”的恢复,不能最大可能的恢复数据;
●数据量大时,恢复较慢。
3 冷备份
冷备份发生在数据库已经正常关闭的情况下,当正常关闭时会提供给我们一个完整的数据库。冷备份时将关键性文件拷贝到另外的位置的一种说法。对于备份Oracle信息而言,冷备份是最快和最安全的方法。
3.1 冷备份中必须拷贝的文件包括
所有数据文件
所有控制文件
所有联机REDO LOG文件
Init.ora文件(可选)
值得注意的是冷备份必须在数据库关闭的情况下进行,当数据库处于打开状态时,执行数据库文件系统备份是无效的。
3.2下面是做冷备份的完整例子
3.2.1 关闭数据库
sqlplus /nolog
sql>connect /as sysdba
sql>shutdown normal;
3.2.2 用拷贝命令备份全部的数据文件、重做日志文件、控制文件、初始化参数文件
可以通过命令select v$tablespace.name,v$datafile.name from v$tablespace, v$datafile where v$tablespace.ts#= v$datafile.ts#;查看相关文件的具体位置。或通过查看Enterprise Manager Console 的初始化参数知道这些文件的具体位置。
3.2.3 重启Oracle数据库
sql>startup
3.3 冷备份的优点
●非常快速、容易的备份方法,只需简单拷贝文件;
●非常容易恢复到某个时间点上,只需将文件再拷贝回去;
●能与归档方法相结合,做数据库“最佳状态”的恢复;
●低度维护,高度安全。
3.4 缺点
●单独使用时,只能提供到“某一时间点上”的恢复;
●实施冷备份的全过程中,数据库必须是关闭状态,因此会影响正常工作;
●不能按表或按用户恢复。
4 热备份
热备份是在数据库运行的情况下,采用archivelog mode方式备份数据库的方法。 |
|