crontab+rman 日期备份脚本

新接手了几个客户的数据库,数据库真是一团糟糕,什么分区,索引,表空间都十分的乱,最重要的是归档都没有开,竟然还是生产库,更别说什么备份脚本了,最近一直在做备份恢复的整理工作,该归档的停机归档,该建立脚本的建立备份脚本,以前库少,现在库多了,管理多个库不能那么空闲了,现在的库之前做了CRONTAB+RMAN的备份,做了些修改,记录如下:

修改RMAN参数以及备份脚本,实现7天后自动删除失效备份集,同时添加定时任务的执行结果到监控邮件。

1:修改RMAN参数

修改RMAN失效日期为7天,同时修改自动备份控制脚本参数为开启状态。

[oracle@localhost ~]$ rman target /

Recovery Manager: Release 10.2.0.1.0 - Production on Tue Jun 21 13:59:31 2011

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

connected to target database: GIS (DBID=3650399296)

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 OFF;# default

CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK TO '%F'; # default

CONFIGURE DEVICE TYPE DISK PARALLELISM 3 BACKUP TYPE TO BACKUPSET;

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

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

CONFIGURE MAXSETSIZE TO UNLIMITED; # default

CONFIGURE ENCRYPTION FOR DATABASE OFF; # default

CONFIGURE ENCRYPTION ALGORITHM 'AES128'; # default

CONFIGURE ARCHIVELOG DELETION POLICY TO NONE; # default

CONFIGURE SNAPSHOT CONTROLFILE NAME TO '/usr/app/db-server/ora_home/dbs/snapcf_gis.f'; # default

RMAN> CONFIGURE CONTROLFILE AUTOBACKUP on;

new RMAN configuration parameters:

CONFIGURE CONTROLFILE AUTOBACKUP ON;

new RMAN configuration parameters are successfully stored

RMAN> CONFIGURE RETENTION POLICY TO RECOVERY WINDOW OF 7 DAYS;

new RMAN configuration parameters:

CONFIGURE RETENTION POLICY TO RECOVERY WINDOW OF 7 DAYS;

new RMAN configuration parameters are successfully stored

RMAN> show all;

RMAN configuration parameters are:

CONFIGURE RETENTION POLICY TO RECOVERY WINDOW OF 7 DAYS;

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 '%F'; # default

CONFIGURE DEVICE TYPE DISK PARALLELISM 3 BACKUP TYPE TO BACKUPSET;

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

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

CONFIGURE MAXSETSIZE TO UNLIMITED; # default

CONFIGURE ENCRYPTION FOR DATABASE OFF; # default

CONFIGURE ENCRYPTION ALGORITHM 'AES128'; # default

CONFIGURE ARCHIVELOG DELETION POLICY TO NONE; # default

CONFIGURE SNAPSHOT CONTROLFILE NAME TO '/usr/app/db-server/ora_home/dbs/snapcf_gis.f'; # default

2:查看过期备份

RMAN> report obsolete;

RMAN retention policy will be applied to the command

RMAN retention policy is set to redundancy 1

Report of obsolete backups and copies

Type                 Key    Completion Time    Filename/Handle

-------------------- ------ ------------------ --------------------

Backup Set           2624   19-JUN-11         

  Backup Piece       2624   19-JUN-11          /sdb/opt/rman/rman/arch_level_0_GIS_20110619_2635_ibmf959t_1_1

Backup Set           2623   19-JUN-11         

  Backup Piece       2623   19-JUN-11          /sdb/opt/rman/rman/arch_level_0_GIS_20110619_2636_icmf959t_1_1

3:删除过期备份集

RMAN> delete noprompt obsolete;

RMAN retention policy will be applied to the command

RMAN retention policy is set to redundancy 1

allocated channel: ORA_DISK_1

channel ORA_DISK_1: sid=94 devtype=DISK

allocated channel: ORA_DISK_2

channel ORA_DISK_2: sid=137 devtype=DISK

allocated channel: ORA_DISK_3

channel ORA_DISK_3: sid=91 devtype=DISK

Deleting the following obsolete backups and copies:

Type                 Key    Completion Time    Filename/Handle

-------------------- ------ ------------------ --------------------

Backup Set           2624   19-JUN-11         

  Backup Piece       2624   19-JUN-11          /sdb/opt/rman/rman/arch_level_0_GIS_20110619_2635_ibmf959t_1_1

Backup Set           2623   19-JUN-11         

  Backup Piece       2623   19-JUN-11          /sdb/opt/rman/rman/arch_level_0_GIS_20110619_2636_icmf959t_1_1

4:修改归档脚本

修改脚本,添加按日期产生文件夹,

[oracle@localhost rman]$ vi archback.sh 

# user env

source ~/.bash_profile

export BACK_DATE=`date +%Y%m%d`

export BACKUP_PATH=/sdb/opt/rman

echo `mkdir -p ${BACKUP_PATH}/archivelog/${BACK_DATE}`

rman target / nocatalog msglog=$BACKUP_PATH/archivelog/${BACK_DATE}/arch_0_$BACK_DATE.log << EOF

# need a user and tablespace to create catalog

#connect catalog rman/rman@$ORACLE_SID;

# resync catalog with target

#resync catalog;

run{

allocate channel c1 type disk;

allocate channel c2 type disk;

allocate channel c3 type disk;

sql 'alter system archive log current';

backup filesperset 3 format '$BACKUP_PATH/archivelog/${BACK_DATE}/arch_level_0_%d_%T_%s_%U' archivelog all delete input;

release channel c1;

release channel c2;

release channel c3;

}

crosscheck backup;

delete noprompt expired backup;

crosscheck archivelog all;

delete noprompt archivelog until time 'sysdate - 1'  all ;

report obsolete;

delete noprompt obsolete;

exit

EOF

# end

5:修改数据备份脚本

[oracle@localhost rman]$ vi fullback.sh 

# user env

source ~/.bash_profile

export BACK_DATE=`date +%Y%m%d`

export BACKUP_PATH=/sdb/opt/rman

echo `mkdir -p ${BACKUP_PATH}/rman/${BACK_DATE}`

rman target / nocatalog msglog=$BACKUP_PATH/rman/${BACK_DATE}/bak_0_$BACK_DATE.log << EOF

# need a user and tablespace to create catalog

#connect catalog rman/rman@$ORACLE_SID;

# resync catalog with target

#resync catalog;

run{

allocate channel c1 type disk;

allocate channel c2 type disk;

allocate channel c3 type disk;

backup full database include current controlfile tag 'dbk_level_0' format '$BACKUP_PATH/rman/${BACK_DATE}/df_level_0_%d_%T_%s_%U';

sql 'alter system archive log current';

backup filesperset 3 format '$BACKUP_PATH/rman/${BACK_DATE}/arch_level_0_%d_%T_%s_%U' archivelog all delete input;

release channel c1;

release channel c2;

release channel c3;

}

crosscheck backup;

delete noprompt expired backup;

crosscheck archivelog all;

delete noprompt archivelog until time 'sysdate'  all ;

report obsolete;

delete noprompt obsolete;

exit

EOF

6:修改Crontab任务

修改如下,增加定时任务失败日志:

[oracle@localhost monitor_client]$ crontab -l

30 01 * * 0 "/usr/app/rman/fullback.sh" >/home/oracle/monitor_client/logs/full_cron.log 2>/home/oracle/monitor_client/logs/full_cron_error.log

00 00 * * 6,1,2,3,4,5 "/usr/app/rman/archback.sh" >/home/oracle/monitor_client/logs/arch_cron.log 2>/home/oracle/monitor_client/logs/arch_cron_error.log

30 7,15 * * * "/home/oracle/monitor_client/client_cron.sh" >/home/oracle/monitor_client/client_cron.log 2>/home/oracle/monitor_client/client_cron_error.log

7:邮件监控脚本修改

增加传送定时任务错误脚本功能,服务器端接收到数据后解析邮件通知

 

contab参考:

http://blog.csdn.net/sipsir/archive/2009/03/08/3973713.aspx

 

错误信息重定向参考:

http://www.phpzixue.cn/detail889.shtml


*******************************************

RMAN定时备份脚本(全备+增量备份+控制文件+参数文件)


  1. ########################################################################  
  2. ##   kfc_incremental_hot_database_backup.sh  ##  
  3. ##   created by  NBU TEMP                    ##  
  4. ##        2012-3-8                           ##  
  5. #########################################################################  
  6.   
  7. #!/bin/ksh  
  8.   
  9. export LANG=en_US  
  10. BACKUP_DATE=`date +%d`  
  11. RMAN_LOG_FILE=/home/oracle/1028/log/backupinfo.out  
  12. TODAY=`date`  
  13. USER=`id|cut -d "(" -f2|cut -d ")" -f1`  
  14. echo "-----------------$TODAY-------------------">$RMAN_LOG_FILE  
  15.   
  16. ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1  
  17. export ORACLE_HOME  
  18.   
  19. RMAN=$ORACLE_HOME/bin/rman  
  20. export RMAN  
  21.   
  22. ORACLE_SID=orcl  
  23. export ORACLE_SID  
  24.   
  25. ORACLE_USER=oracle  
  26. export ORACLE_USER  
  27.   
  28. echo "ORACLE_SID: $ORACLE_SID">>$RMAN_LOG_FILE  
  29. echo "ORACLE_HOME:$ORACLE_HOME">>$RMAN_LOG_FILE  
  30. echo "ORACLE_USER:$ORACLE_USER">>$RMAN_LOG_FILE  
  31. echo "==========================================">>$RMAN_LOG_FILE  
  32. echo "BACKUP DATABASE BEGIN......">>$RMAN_LOG_FILE  
  33. echo "                   ">>$RMAN_LOG_FILE  
  34.   
  35. #touch $RMAN_LOG_FILE  
  36. chmod 666 $RMAN_LOG_FILE  
  37.   
  38. WEEK_DAILY=`date +%a`  
  39.   
  40. case  "$WEEK_DAILY" in  
  41.        "Mon")  
  42.             BAK_LEVEL=1  
  43.             ;;  
  44.        "Tue")  
  45.             BAK_LEVEL=1  
  46.             ;;  
  47.        "Wed")  
  48.             BAK_LEVEL=1  
  49.             ;;  
  50.        "Thu")  
  51.             BAK_LEVEL=1  
  52.             ;;  
  53.        "Fri")  
  54.             BAK_LEVEL=1  
  55.             ;;  
  56.        "Sat")  
  57.             BAK_LEVEL=0  
  58.             ;;  
  59.        "Sun")  
  60.             BAK_LEVEL=1  
  61.             ;;  
  62.        "*")  
  63.             BAK_LEVEL=error  
  64. esac  
  65.   
  66. export BAK_LEVEL=$BAK_LEVEL  
  67.   
  68. echo "Today is : $WEEK_DAILY  incremental level= $BAK_LEVEL">>$RMAN_LOG_FILE  
  69.   
  70.   
  71. RUN_STR="  
  72.   
  73. BAK_LEVEL=$BAK_LEVEL  
  74. export BAK_LEVEL  
  75.   
  76. ORACLE_HOME=$ORACLE_HOME  
  77. export ORACLE_HOME  
  78.   
  79. ORACLE_SID=$ORACLE_SID  
  80. export ORACLE_SID  
  81.   
  82. $RMAN nocatalog TARGET sys/oracle msglog $RMAN_LOG_FILE append <<EOF  
  83. run  
  84. {  
  85.   allocate channel c1 type disk;  
  86.   allocate channel c2 type disk;  
  87.   
  88.   backup  incremental level= $BAK_LEVEL  skip inaccessible filesperset 5 Database format='/home/oracle/1028/backup/orcl_lev"$BAK_LEVEL"_%U_%T'  tag='orcl_lev"$BAK_LEVEL"' ;  
  89.   
  90.   sql 'alter system archive log current';  
  91.   
  92.   backup archivelog all tag='arc_bak' format='/home/oracle/1028/backup/arch_%U_%T' skip inaccessible  filesperset 5 not  backed up 1 times  delete input;  
  93.   
  94.   backup current controlfile tag='bak_ctlfile' format='/home/oracle/1028/backup/ctl_file_%U_%T';  
  95.   
  96.   backup spfile tag='spfile' format='/home/oracle/1028/backup/ORCL_spfile_%U_%T';  
  97.   
  98.   release channel c2;  
  99.   release channel c1;  
  100. }  
  101.   
  102. report obsolete;  
  103. delete noprompt obsolete;  
  104. crosscheck backup;  
  105. delete noprompt expired backup;  
  106. list backup summary;  
  107. EOF  
  108.   
  109. "  
  110. # Initiate the command string  
  111.   
  112. if [ "$CUSER" = "root" ]  
  113. then  
  114.     echo "Root Command String: $RUN_STR" >> $RMAN_LOG_FILE  
  115.     su - $ORACLE_USER -c "$RUN_STR" >> $RMAN_LOG_FILE  
  116.     RSTAT=$?  
  117. else  
  118.     echo "User Command String: $RUN_STR" >> $RMAN_LOG_FILE  
  119.     /bin/sh -c "$RUN_STR" >> $RMAN_LOG_FILE  
  120.     RSTAT=$?  
  121. fi  
  122.   
  123. # ---------------------------------------------------------------------------  
  124. # Log the completion of this script.  
  125. # ---------------------------------------------------------------------------  
  126.   
  127. if [ "$RSTAT" = "0" ]  
  128. then  
  129.     LOGMSG="ended successfully"  
  130. else  
  131.     LOGMSG="ended in error"  
  132. fi  
  133.   
  134. echo >> $RMAN_LOG_FILE  
  135. echo Script $0 >> $RMAN_LOG_FILE  
  136. echo ==== $LOGMSG on `date` ==== >> $RMAN_LOG_FILE  
  137. echo >> $RMAN_LOG_FILE  
  138.   
  139. exit $RSTAT 



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值