Oracle数据库备份详细讲解
. OracleOracle 数据库备份详解数据库备份详解 ORACLE 数据库有两类备份方法。第一类为物理备份,该方法实现数据库的完整恢复, 但数据库必须运行在归挡模式下(业务数据库在非归挡模式下运行) ,且需要极大的外部存 储设备,例如磁带库;第二类备份方式为逻辑备份,业务数据库采用此种方式,此方法不需 要数据库运行在归挡模式下,不但备份简单,而且可以不需要外部存储设备。 一、数据库逻辑备份方法一、数据库逻辑备份方法 1 1 导出工具:导出工具:expexp Exp 它是操作系统下一个可执行的文件 存放目录/ORACLE_HOME/bin exp 导出工具将数据库中数据备份压缩成一个二进制系统文件.可以在不同 OS 间迁移 ORACLE 数据库的逻辑备份分为三种模式: a.表模式: 导出用户所有表或者指定的表; b.用户模式: 导出用户所有对象以及对象中的数据; c.整个数据库: 导出数据库中所有对象。 1.11.1 表模式表模式 备份某个用户模式下指定的对象(表) 。业务数据库通常采用这种备份方式。 若备份到本地文件,使用如下命令: exp icdmain/icd rows=y inds=n compress=n buffer=65536 feedback=100000 volsize=0 file=exp_icdmain_csd_yyyymmdd.dmp log=exp_icdmain_csd_yyyymmdd.log tables= monination,icdmain.serviceinfo,icdmain.dealinfo 若直接备份到磁带设备,使用如下命令: exp icdmain/icd rows=y inds=n compress=n buffer=65536 feedback=100000 volsize=0 file=/dev/rmt0 log=exp_icdmain_csd_yyyymmdd.log tables= monination,icdmain.serviceinfo,icdmain.dealinfo 注:在磁盘空间允许的情况下, 应先备份到本地服务器,然后再拷贝到磁带。出于速度方面 的考虑,尽量不要直接备份到磁带设备。 1.21.2 用户模式用户模式 备份某个用户模式下的所有对象。业务数据库通常采用这种备份方式。 . . 若备份到本地文件,使用如下命令: exp icdmain/icd owner=icdmain rows=y inds=n compress=n buffer=65536 feedback=100000 volsize=0 file=exp_icdmain_yyyymmdd.dmp log=exp_icdmain_yyyymmdd.log 若直接备份到磁带设备,使用如下命令: exp icdmain/icd owner=icdmain rows=y inds=n compress=n buffer=65536 feedback=100000 volsize=0 file=/dev/rmt0 log=exp_icdmain_yyyymmdd.log 注:如果磁盘有空间,建议备份到磁盘,然后再拷贝到磁带。如果数据库数据量较小,可采 用这种办法备份。 1.31.3 完全模式完全模式 备份完整的数据库。业务数据库不采用这种备份方式。备份命令为: exp icdmain/icd rows=y inds=n compress=n buffer=65536 feedback=100000 volsize=0 full=y file=exp_fulldb_yyyymmdd.dmp(磁带设备则为/dev/rmt0) log=exp_fulldb_yyyymmdd.log 对于数据库备份, 建议采用增量备份, 即只备份上一次备份以来更改的数据。 增量备份命令: exp icdmain/icd rows=y inds=n compress=n buffer=65536 feedback=100000 volsize=0 full=y inctype=incremental file=exp_fulldb_yyyymmdd.dmp(磁带设备则为/dev/rmt0) log=exp_fulldb_yyyymmdd.log 注:关于增量备份必须满足下列条件: 1. 只对完整数据库备份有效,且第一次需要full=y 参数,以后需要inctype=incremental 参数。 2. 用户必须有 EXP_FULL_DATABASE的系统角色。 3. 话务量较小时方可采用数据库备份。 4. 如果磁盘有空间,建议备份到磁盘,然后再备份到磁带。 业务数据库备份方法及周期 用 EXP 进行备份前,先在 SYS 用户下运行 CATEXP.SQL 文件(如果以前已运行该文件,则不 要执行这个脚本) 。 没有特殊说明,不允许在客户端执行备份命令。 备份命令参照表模式下的备份命令。 1.41.4 从磁盘文件备份到磁带从磁盘文件备份到磁带 如果首先备份到本地磁盘文件,则需要转储到磁带设备上。 . . 1.4.1.1.4.1. 若需查看主机上配置的磁带设备,使用如下命令:若需查看主机上配置的磁带设备,使用如下命令: lsdev -Cc tape 显示的结果如下例所示: rmt0 Available 30-58-00-2,0 SCSI 4mm Tape Drive rmt1 Defined 30-58-00-0,0 SCSI 4mm Tape Drive 标明 Available 的设备是可用的磁带设备。 1.4.2.1.4.2. 若需查看磁带存储的容,使用如下命令:若需查看磁带存储的容,使用如下命令: tar -tvf /dev/rmt0 显示的结果如下例所示: -rw-r--r-- 300 400 8089600 Jan 11 14:33:57 2001 exp_icdmain_20010111.dmp 如果显示类似如下容, 则表示该磁带存储的备份数据是从数据库直接备份到磁带上, 而非从 本地磁盘转储到磁带的备份文件,因此操作系统无法识别。 tar: 0511-193 An error occurred while reading from the media. There is an or output error. 或 tar: 0511-169 A directory checksum error on media; -267331077 not equalto 2 5626. 1.4.3.1.4.3. 对于新磁带或无需保留现存数据的磁带,使用如下命令:对于新磁带或无需保留现存数据的磁带,使用如下命令: tar -cvf /dev/rmt0 exp_icdmain_yyyymmdd.dmp 注:A. 该命令将无条件覆盖磁带上的现存数据。 B. 文件名不允许包含路径信息,如:/backup/exp_icdmain_yyyymmdd.dmp。 1.4.4. 对于需要保留现存数据的磁带,使用如下命令: tar -rvf /