RMAN热备份

    技术2024-11-02  26

    RMAN热备份

    1       概述 Recovery Manager(RMAN)是一种用于备份(backup)、还原(restore)和恢复(recover)数据库 的 Oracle 工具。RMAN只能用于ORACLE8或更高的版本中。它能够备份整个数据库或数据库部件,如表空间、数据文件、控制文件、归档文件以 及Spfile参数文件。RMAN也允许您进行增量数据块级别的备份,增量RMAN备份是时间和空间有效的,因为他们只备份自上次备份以来有变化的那些数 据块。而且,通过RMAN提供的接口,第三方的备份与恢复软件如veritas将提供更强大的备份与恢复的管理功能。通过RMAN,也提供了其它更多功 能,如数据库的克隆、采用RMAN建立备用数据库、利用RMAN备份与移动裸设备(RAW)上的文件等工作将变得更方便简单。9i的RMAN通过增强的自 动配置与管理功能,以及特有的块级别的恢复,将使备份与恢复工作变得更加快捷与完美。9i的RMAN有如下特征特性:

    ·自动的备份与恢复

    ·方便的备份归档日志

    ·自动检测新的数据文件

    ·支持增量备份

    ·最大限度的减少备份与恢复的错误

    ·减少恢复的时间

    ·在热备份中不会产生额外的redo日志

    ·腐烂数据块的自动检测

    ·并行的备份与恢复操作

    ·在线备份时,表空间不用置于备份模式

    可以看到,在以上的一些特性中,显示了RMAN强大的功能与好处,以上功能的实现,是因为RMAN是块级别的备份与恢复,备份与恢复发生在数据库块级别,可以通过比较数据块而获得一致性的数据块,可以避免备份没有用过的块,可以检验块是否腐烂等块级别的问题。

    2       启动与运行RMAN要求 2.1    进程与内存要求 更多的进程的需要

    大池的分配

    2.2    基本环境变量需求 ORACLE_SID, ORACLE_HOME, PATH, NLS_LANG, 如果用到了基于时间的备份与    恢复,需要另外设置NLS_DATE_FORMAT

    2.3    权限要求 需要SYSDBA系统权限,如果是本地,可以采用OS认证,远程需要采用密码文件认证

    2.4    版本要求 ·RMAN 工具版本与目标数据库必须是同一个版本,如果使用了恢复目录,还需要注意

    ·创建RMAN 恢复目录的脚本版本必须等于或大于恢复目录所在数据库的版本

    ·创建RMAN 恢复目录的脚本版本必须等于或大于目标数据库的版本

    3       RMAN的自动配置 Oracle 9i可以配置一些参数如通道,备份保持策略等信息,通过一次设定可以多次使用,

    而且,设置中的信息不影响脚本中的重新设置。RMAN 默认的配置参数,通过show all 就

    可以看出来。

    RMAN> show all;

    RMAN configuration parameters are:

    CONFIGURE RETENTION POLICY TO REDUNDANCY 1; # default

    CONFIGURE BACKUP OPTIMIZATION OFF; # default

    CONFIGURE DEFAULT DEVICE TYPE TO DISK; # default

    CONFIGURE CONTROLFILE AUTOBACKUP ON;

    CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK TO '/orabackup/rmanbk/%F';

    CONFIGURE DEVICE TYPE DISK PARALLELISM 1; # default

    CONFIGURE DATAFILE BACKUP COPIES FOR DEVICE TYPE DISK TO 1; # default

    CONFIGURE ARCHIVELOG BACKUP COPIES FOR DEVICE TYPE DISK TO 1; # default

    RMAN configuration has no stored or default parameters

    RMAN configuration has no stored or default parameters

    CONFIGURE MAXSETSIZE TO UNLIMITED; # default

    CONFIGURE SNAPSHOT CONTROLFILE NAME TO '/oracle/product/9.2/dbs/snapcf_gdtel1.f'; # default

    3.1    备份策略保持 CONFIGURE RETENTION POLICY TO REDUNDANCY 3;

    保持最少3个冗余备份集

    3.2    通道配置与自动通道分配 通过CONFIGURE 配置自动分配的通道,而且可以通过数字来指定不同的通道分配情

    况。

    CONFIGURE CHANNEL DEVICE TYPE DISK FORMAT '/orabackup/rmanbk/%U‘

    CONFIGURE CHANNEL n DEVICE TYPE DISK FORMAT '/orabackup/rmanbk/%U‘

    也可以通过手工来进行RMAN通道的配置

    allocate channel cq type disk format='/orabackup/rmanbk/%U '

    3.3    控制文件自动备份 CONFIGURE CONTROLFILE AUTOBACKUP ON;

    CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK TO '/orabackup/rmanbk/%F';

    3.4    设置并行备份 可以设置并行备份的并行数,以加快备份的速度,一般并行数为CPU的个数,因目前数据量不大,暂时不对并行数进行设置

    CONFIGURE DEVICE TYPE DISK PARALLELISM 4;

    3.5    配置默认IO 设备类型 备份IO 设备类型可以是磁盘或者磁带,在默认的情况下是磁盘,可以通过如下的命令进行重新配置。

    CONFIGURE DEFAULT DEVICE TYPE TO DISK;

    CONFIGURE DEFAULT DEVICE TYPE TO SBT;

    目前将采用磁盘备份,建议加入磁带进行长期备份

    3.6    配置多个备份的拷贝数目 如果觉得单个备份集不放心,可以设置多个备份集的拷贝,如

    CONFIGURE DATAFILE BACKUP COPIES FOR DEVICE TYPE DISK TO 2;

    CONFIGURE ARCHIVELOG BACKUP COPIES FOR DEVICE TYPE DISK TO 2;

    目前主要是在本地备份,同时在异地保存备份来保证备份集的可用性,配置多个备份的拷贝会导致备份性能的降低,故暂时不作多个备份的拷贝

    4       用RMAN备份 RMAN可以用来备份主或备用数据库,如表空间、数据文件、归档日志、控制文件、服务

    器文件与备份集。

    4.1    文件拷贝 原始文件的拷贝,有点类似于OS热备份,可以拷贝整个数据文件到另外一个地点,但是结果仅仅只能写入到硬盘,而且单独的文件是分开的。因本备份方案主要是针对RAC裸设备进行备份,为了保证备份的可靠性,故不采用文件拷贝的方式

    4.2    全备份 全备份,对数据库中spfile,controlfile,datafile,archivelogfile

    数据库全备份脚本:

    run {

    backup database include current controlfile format '/orabackup/rmanbk/%U_%s.bak';

    sql 'alter system archive log current' ;

    ALLOCATE CHANNEL node_c1 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel1' ;

    ALLOCATE CHANNEL node_c2 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel2' ;

    sql 'ALTER SYSTEM ARCHIVE LOG CURRENT';

    backup archivelog all delete input format '/orabackup/rmanbk/%U_%s.bak';

    }

    4.3    多级增量备份 多级增量备份是指第N级的备份只需要备份最后一次同级或N-1级备份以后发生的改变的数据。可以通过下图来说明:

    上图是一个增量备份的例子,即在第一个星期天做一个增量的0级备份,然后在星期一,星期二做一个增量的2级备份,在星期三做一个增量的1级备份,然后类 推。假设现在在星期五数据库需要做恢复,则可以先恢复第一个星期天的0级备份,,然后恢复星期三的1级备份,再恢复星期四和星期五的2级备份就可以完成数 据库的恢复。

    1、  零级备份脚本

    run {

    backup database incremental level 0 format '/orabackup/rmanbk/%U_%s.bak';

    sql 'alter system archive log current' ;

    ALLOCATE CHANNEL node_c1 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel1' ;

    ALLOCATE CHANNEL node_c2 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel2' ;

    sql 'ALTER SYSTEM ARCHIVE LOG CURRENT';

    backup archivelog all delete input format '/orabackup/rmanbk/%U_%s.bak';

    }

    2、  一级备份脚本

    run {

    backup database incremental level 1 format '/orabackup/rmanbk/%U_%s.bak';

    sql 'alter system archive log current' ;

    ALLOCATE CHANNEL node_c1 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel1' ;

    ALLOCATE CHANNEL node_c2 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel2' ;

    sql 'ALTER SYSTEM ARCHIVE LOG CURRENT';

    backup archivelog all delete input format '/orabackup/rmanbk/%U_%s.bak';

    }

    3、  二级备份脚本

    run {

    backup database incremental level 2 format '/orabackup/rmanbk/%U_%s.bak';

    sql 'alter system archive log current' ;

    ALLOCATE CHANNEL node_c1 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel1' ; #2 NODES RAC SYSTEM

    ALLOCATE CHANNEL node_c2 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel2' ;

    sql 'ALTER SYSTEM ARCHIVE LOG CURRENT';

    backup archivelog all delete input format '/orabackup/rmanbk/%U_%s.bak';

    }

    4.4    备份检查 我们可以通过Validate命令来检查是否能备份,如数据文件是否存在,是否存在坏块      不被备份,如:

    BACKUP VALIDATE DATABASE;

    BACKUP VALIDATE DATABASE ARCHIVELOG ALL;

    4.5    重新启动备份 对于异常结束了的备份,很多人可能不想再重新开始备份了吧,特别是备份到90%以上,因为异常原因终止了该备份,那怎么办呢?RMAN 提供一个重新开始备份的方法,通过简单的命令,你就可以只备份那不到10%的数据了。

    RMAN> BACKUP NOT BACKED UP SINCE TIME 'SYSDATE-14'

    2> DATABASE PLUS ARCHIVELOG;

    5       自动备份脚本 5.1    全备份自动脚本 rmanbackup_full.sh

    #!/bin/sh

    #set env

    export ORACLE_HOME=/oracle/product/9.2

    export ORACLE_SID=gdtel1

    export NLS_LANG="AMERICAN_AMERICA.zhs16gbk"

    export PATH=$PATH:$ORACLE_HOME/bin:/sbin:/usr/sbin

    echo "-----------------------------start-----------------------------";date

    #backup start

    $ORACLE_HOME/bin/rman <<EOF

    connect target

    delete noprompt obsolete;

    backup database include current controlfile format '/orabackup/rmanbk/%U_%s.bak';

    run{

            ALLOCATE CHANNEL node_c1 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel1' ;

            ALLOCATE CHANNEL node_c2 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel2' ;

            sql 'ALTER SYSTEM ARCHIVE LOG CURRENT';

            backup archivelog all delete input format '/orabackup/rmanbk/%U_%s.bak';

    }

    list backup;

    exit;

    EOF

    echo "------------------------------end------------------------------";date

    5.2    0级备份自动脚本 rmanbackup_level0.sh

    #!/bin/sh

    #set env

    export ORACLE_HOME=/oracle/product/9.2

    export ORACLE_SID=gdtel1

    export NLS_LANG="AMERICAN_AMERICA.zhs16gbk"

    export PATH=$PATH:$ORACLE_HOME/bin:/sbin:/usr/sbin

    echo "-----------------------------start-----------------------------";date

    #backup start

    $ORACLE_HOME/bin/rman <<EOF

    connect target

    delete noprompt obsolete;

    backup database incremental level 0 format '/orabackup/rmanbk/%U_%s.bak' ;

    run{

            ALLOCATE CHANNEL node_c1 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel1' ;

            ALLOCATE CHANNEL node_c2 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel2' ;

            sql 'ALTER SYSTEM ARCHIVE LOG CURRENT';

            backup archivelog all delete input format '/orabackup/rmanbk/%U_%s.bak';

    }

    list backup;

    exit;

    EOF

    echo "------------------------------end------------------------------";date

    5.3    1级备份自动脚本 rmanbackup_level1.sh

    #!/bin/sh

    #set env

    export ORACLE_HOME=/oracle/product/9.2

    export ORACLE_SID=gdtel1

    export NLS_LANG="AMERICAN_AMERICA.zhs16gbk"

    export PATH=$PATH:$ORACLE_HOME/bin:/sbin:/usr/sbin

    echo "-----------------------------start-----------------------------";date

    #backup start

    $ORACLE_HOME/bin/rman <<EOF

    connect target

    delete noprompt obsolete;

    backup database incremental level 0 format '/orabackup/rmanbk/%U_%s.bak';

    run{

            ALLOCATE CHANNEL node_c1 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel1' ;

            ALLOCATE CHANNEL node_c2 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel2' ;

            sql 'ALTER SYSTEM ARCHIVE LOG CURRENT';

            backup archivelog all delete input format '/orabackup/rmanbk/%U_%s.bak';

    }

    list backup;

    exit;

    EOF

    echo "------------------------------end------------------------------";date

    5.4    2级备份自动脚本 rmanbackup_level2.sh

    #!/bin/sh

    #set env

    export ORACLE_HOME=/oracle/product/9.2

    export ORACLE_SID=gdtel1

    export NLS_LANG="AMERICAN_AMERICA.zhs16gbk"

    export PATH=$PATH:$ORACLE_HOME/bin:/sbin:/usr/sbin

    echo "-----------------------------start-----------------------------";date

    #backup start

    $ORACLE_HOME/bin/rman <<EOF

    connect target

    delete noprompt obsolete;

    backup database incremental level 0 format '/orabackup/rmanbk/%U_%s.bak';

    run{

            ALLOCATE CHANNEL node_c1 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel1' ; #2NODES RAC SYSTEM

            ALLOCATE CHANNEL node_c2 DEVICE TYPE DISK CONNECT 'sys/sys@gdtel2' ;

            sql 'ALTER SYSTEM ARCHIVE LOG CURRENT';

            backup archivelog all delete input format '/orabackup/rmanbk/%U_%s.bak';

    }

    list backup;

    exit;

    EOF

    echo "------------------------------end------------------------------";date

    5.5    脚本部署 5.5.1   使用oracle用户登录系统 5.5.2   系统目录准备 1、  准备orabackup分区,该分区要尽可能大,以容纳更多的备份数据

    2、  挂接分区到 /orabackup

    3、  修改文件在服务器启动的时候自动挂接

    4、  建立以下目录 

    脚本存放目录:/orabackup/bin; 

    备份数据存放目录:/orabackup/rmanbk/

    备份日志存放目录:/orabackup/logs

    5.5.3   编写cron.backup脚本 分钟 小时       月    日    星期       执行的命令

    00     00    *     *     0     /orabackup/bin/rmanbk_level0.sh         #周日晚做0级备份

    00     00    *     *     1     /orabackup/bin/rmanbk_level0.sh         #周一晚做2级备份

    00     00    *     *     2     /orabackup/bin/rmanbk_level0.sh         #周二晚做2级备份

    00     00    *     *     3     /orabackup/bin/rmanbk_level0.sh         #周三晚做1级备份

    00     00    *     *     4     /orabackup/bin/rmanbk_level0.sh         #周四晚做2级备份

    00     00    *     *     5     /orabackup/bin/rmanbk_level0.sh         #周五晚做2级备份

    00     00    *     *     6     /orabackup/bin/rmanbk_full.sh             #周六晚做全备份

    之间的空格请使用键盘的TAB键隔开,否则不起作用,另外:运行命令的目录请按脚本存放的实际目录进行修改

    5.5.4   执行自动运行计划 $crontab –u oracle cron.backup

    修改:crontab –e

    最新回复(0)