当前位置:Gxlcms > 数据库问题 > 使用 RMAN 同步数据库

使用 RMAN 同步数据库

时间:2021-07-01 10:21:17 帮助过:3人阅读

2. Sql>shutdown immediate;

3. Sql>startup mount;

4. Sql>alter database archivelog;

5. Sql>alter database open;

6. Sql>quit

(二).启动rman做数据库0级备份

1. [oracle@primary orcl]$ rman target /

2. RMAN>CONFIGURE CONTROLFILE AUTOBACKUP ON;

3. RMAN> backup incremental level 0 database format ‘full_db_%d_%s_%t_%p‘;

--第一次同步操作时用该语句。

RMAN>quit;

日常同步备份时使用1级备份

4. [oracle@primary orcl]$ rman target /

5. RMAN>CONFIGURE CONTROLFILE AUTOBACKUP ON;

6. RMAN> backup incremental level 1 database format ‘increment _db_%d_%s_%t_%p‘;

7. RMAN>quit;

(三).修改生产库数据库到未归档.

1. [oracle@primary orcl]$ Sqlplus ‘/as sysdba’

2. Sql>alter database noarchivelog;

3. Sql>alter database open;

4. Sql>quit;

(四).拷贝备份集到测试库

拷贝备份集文件到测试库,并和生产库相同位置,可以使用sftp或ftp等工具完成。

(五).在测试库上的操作

1. [oracle@primary orcl]$ Sqlplus ‘/as sysdba’

2. Sql>startup nomount;

3. Sql>quit;

4. [oracle@primary orcl]$ rman target /

5. RMAN> restore controlfile from/opt/oracle11g/u01/dbs/c-1190421672-20080819-01‘;

--该处可修改为实际备份集。

6. RMAN> alter database mount;

7. RMAN> restore database;

8. RMAN> recover database;

9. RMAN>alter database open resetlogs;

注意,所有的增量或差异备份都是用recover database来恢复的,如果丢失增量备份,需用下面方法启动数据库,将可能导致丢失大量数据:

启动sqlplus,使用下面语句清除丢失的增量备份.

Sql>recover database using backup controlfile until cancel;

ORA-00279: ü 1839635 ( 08/18/2008 23:25:21 ú) 1 ±è

ORA-00289: ¨é: /archive/1_74_662640938.dbf

ORA-00280: ü 1839635 ( 1) ò #74

Specify log: {=suggested | filename | AUTO | CANCEL}

Cancel <需要手工输入后回车>

Media recovery cancelled.

最后执行resetlogs关键字启动数据库。

SQL> alter database open resetlogs;

Database altered.

备份及同步脚本:
 rman_backup_v1.1.sh

点击(此处)折叠或打开

  1. #!/bin/bash 
  2. ################################################################### 
  3. # Usage: 
  4. # backup_rman_v1.1.sh [all|repeat|sync] 
  5. # all: list all backup file. 
  6. # repeat: repeat level-1 increment backup. 
  7. # sync: sync backup file to target database. 
  8. ################################################################### 
  9. export ORACLE_HOME=/opt/oracle11g/u01 
  10. export ORACLE_SID=primary 
  11. export LD_LIBRARY_PATH=${ORACLE_HOME}/lib:${ORACLE_HOME}/ctx/lib 
  12. export PATH=$PATH:${ORACLE_HOME}/bin 
  13. export NLS_LANG="American_america.zhs16gbk" 
  14. export ORACLE_OWNER=oracle 
  15. export backup_dir=/home/oracle/backup/backup 
  16. export log=/home/oracle/backup/log 
  17. rsync_dir=$backup_dir #sync dir 
  18. controlfile_dir=$backup_dir/controlfile 
  19. username=oracle #target OS ,oracle user 
  20. password=go2north #target oracle user password 
  21. target_host=172.16.5.27 
  22. today_backup=`date +‘%Y-%m-%d‘` 
  23. mail_to_admin="zhaorupeng@126.com" 
  24. ########set display color######### 
  25. white=$(echo -e "\e[39;40m") 
  26. green=$(echo -e "\e[36;40m") 
  27. red=$(echo -e "\e[31;40m") 
  28. purple=$(echo -e "\e[35;40m") 
  29. yellow=$(echo -e "\e[33;40m") 
  30. blue=$(echo -e "\e[34;40m") 
  31. ########color set end ############
  32. # data backup status. 
  33. # 0: backup failed. 
  34. # 2: default 
  35. # 9: success 
  36. backup_status=2
  37. #database status check ,If it‘s not turn on,the value is 0,or else 1 
  38. ora_stat=`ps -ef | grep -i ‘ora_smon_*‘ |grep -v grep| wc -l`
  39. #database mode check,If it‘s archive mode,that value is 1,or else 0; 
  40. arch=`ps -ef | grep -i ‘ora_arc_*‘ | grep -v grep | wc -l`
  41. function open_database() 
  42. if [ "$ora_stat" = 0 ]; then 
  43. cat << EOF | $ORACLE_HOME/bin/sqlplus ‘/as sysdba‘ 
  44. shutdown immediate; 
  45. startup; 
  46. quit; 
  47. EOF 
  48. backup_status=2 
  49. if [ "$?" = 1 ]; then 
  50. echo "database unable strtup!" 
  51. backup_status=0 
  52. exit 1 
  53. fi 
  54. fi 
  55. function open_archive_mode() 
  56. if [ "$arch" = 0 ]; then #if arch=1,nothing,because it was already on archive mode 
  57. echo "****************open archive mode*************" 
  58. cat << EOF | $ORACLE_HOME/bin/sqlplus ‘/as sysdba‘ 
  59. shutdown immediate; 
  60. startup mount; 
  61. alter database archivelog; 
  62. alter database open; 
  63. quit; 
  64. EOF 
  65. fi 
  66. function return_initaliztion_mode() 
  67. if [ "$arch" = 0 -a "$backup_status" > 0 ]; then 
  68. #if arch=1,nothing,because initialization mode is archive mode 
  69. echo "********* return initialization database mode**********" 
  70. cat << EOF | $ORACLE_HOME/bin/sqlplus ‘/as sysdba‘ 
  71. shutdown immediate; 
  72. startup mount; 
  73. alter database noarchivelog; 
  74. alter database open; 
  75. quit; 
  76. EOF 
  77. fi 
  78. if [ "$?" = 0 ]; then 
  79.     echo "return initalization database successfully." 
  80. fi 
  81. echo "************return initialization database mode *********" ; 
  82. function increment_backup_level_1() # incremental level-1 backup 
  83. open_database 
  84. open_archive_mode 
  85. echo "******** `date +‘%Y%m%d‘` Do level-1 increment backup....*********************" 2>&1;
  86. cat << EOF | $ORACLE_HOME/bin/rman target / |tee $log/rman_increment_db_`date +‘%y%m%d%H%M‘`.log 
  87. configure maxsetsize to 20g; 
  88. configure controlfile autobackup on; 
  89. configure controlfile autobackup format for device type disk to ‘$controlfile_dir/%F‘; 
  90. run { 
  91. allocate channel c01 type disk; 
  92. backup incremental level 1 database format ‘$backup_dir/increment_db_%d_%s_%t_%p‘ tag="increment_db_`date +‘%y%m%d%H%M‘`"; 
  93. release channel c01; 
  94. configure controlfile autobackup off; 
  95. crosscheck backup of database; 
  96. crosscheck archivelog all; 
  97. delete noprompt obsolete ; 
  98. delete noprompt expired backup; 
  99. delete noprompt backup completed before ‘sysdate-30‘; 
  100. delete noprompt archivelog until time ‘sysdate-14‘; 
  101. EOF 
  102. if [ "$?" = 0 ];then 
  103.     echo "*******************level-1 backup completed!************************" 
  104.         backup_status=9 
  105. else 
  106.     echo "*****************level-1 backup databae failed,please contact oracle dba*******" 
  107.     backup_status=0 
  108. fi 
  109. return $backup_status 
  110. return_initaliztion_mode 
  111. function level_0_backup_database() 
  112. open_database 
  113. open_archive_mode 
  114. echo "************* Do level-0 backup ****************" 
  115. cat << EOF | $ORACLE_HOME/bin/rman target / |tee $log/rman_full_db_`date +‘%y%m%d%H%M‘`.log 
  116. configure retention policy to redundancy 30; 
  117. configure maxsetsize to 20g; 
  118. configure controlfile autobackup on; 
  119. configure controlfile autobackup format for device type disk to ‘$controlfile_dir/%F‘; 
  120. crosscheck backup of database; 
  121. crosscheck archivelog all; 
  122. delete noprompt obsolete ; 
  123. delete noprompt expired backup; 
  124. delete noprompt backup completed before ‘sysdate-30‘; 
  125. delete noprompt archivelog until time ‘sysdate-5‘; 
  126. run { 
  127. allocate channel c1 type disk; 
  128. backup incremental level 0 database format ‘$backup_dir/full_db_%d_%s_%t_%p‘ tag="full_db_`date +‘%y%m%d%H%M‘`"; 
  129. release channel c1 ; 
  130. configure controlfile autobackup off; 
  131. quit; 
  132. EOF 
  133. if [ "$?" = 0 ];then 
  134.     echo "*******************level-0 backup completed!************************" 
  135.         backup_status=9 
  136. else 
  137.     echo "******************level-0 backup databae failed,please contact oracle dba*******"
  138.     backup_status=0 
  139. fi 
  140. return $backup_status 
  141. return_initaliztion_mode 
  142. function repeat_increment_backup() 
  143.     if [ "$#" = 0 ]; then 
  144.         exit 0 
  145.     else
  146.           if [ "$1" = "repeat" ]; then 
  147.             echo "************do database increment backup again**************" 
  148.             increment_backup_level_1 $ORACLE_HOME $log $backup_dir 
  149.             echo "************repeat increment backup completed!**************" 
  150.           else 
  151.             echo "command error,please use parameter ‘repeat‘" 
  152.             exit 0 
  153.           fi 
  154.     fi 
  155. }
  156. # sync target database backup files # 
  157. function sync() 
  158. ping $target_host -c 1 > /dev/null # test network link # 
  159. if [ $? != 0 ] ; then 
  160.     echo "sync host:$red $target_host $white link failed!,please check network." 
  161.     exit 1 
  162. fi 
  163. if [ -f /usr/bin/rsync ]; then 
  164. #check resync command # 
  165.    cat << EOF > sync 
  166. #!/usr/bin/expect 
  167. spawn /usr/bin/rsync -avzu $rsync_dir/ $username@$target_host:$rsync_dir 
  168. expect "password:" 
  169. send "$password\n"; 
  170. send "quit\n"; 
  171. interact 
  172. EOF 
  173. echo "********copy backup files to target database********" 
  174.   if [ -f sync -a -f /usr/bin/expect ]; then 
  175.     chmod +x sync 
  176.     ./sync 
  177.     rm -rf ./sync 
  178. #list sync files 
  179. backup_file=`ls -ltR --full-time $backup_dir/ | egrep -i "increment_|c-" | grep -i $today_backup | awk ‘{print $6 " " substr($7,1,8) " " $9}‘` 
  180.     echo "sync files:" 
  181.     echo "$blue" 
  182.     j=0 
  183.     for i in $backup_file 
  184.     do 
  185.         ((j++)) 
  186.         a[$j]=$i 
  187.         if [ $j = 3 ]; then 
  188.             echo "${a[`expr $j - 2`]} ${a[`expr $j - 1`]} ${a[$j]}" 
  189.              j=0 
  190.         fi 
  191.     done 
  192.     echo "$white" 
  193.     echo " transtion has succeed.please check the backup files on target database." 
  194.     exit 0 
  195.    else 
  196.       echo "command expect not found, please install Tcl/expect" 
  197.       exit 1 
  198.    fi 
  199. else 
  200.     echo "command rsync not found,please install!" 
  201.     exit 1 
  202. fi 
  203. if [ -f $log/autobak_`date +‘%Y%m%d‘`.log ]; then 
  204.     rm -rf $log/autobak_`date +‘%Y%m%d‘`.log 
  205. fi 
  206. level_0_backup_status=`find $backup_dir/ -name ‘full_db_*‘| grep -i full_db |grep -v grep | wc -l` 2>&1 
  207. level_1_backup_status=`ls -l --full-time $backup_dir/ |grep -i ‘increment_db_*‘| grep -i $today_backup|grep -v grep | wc -l` 2>&1 
  208. if [ $level_0_backup_status = 0 -a $backup_status = 2 ]; then 
  209.     level_0_backup_database 
  210.     backup_status=$? 
  211. fi 
  212. if [ $level_1_backup_status = 0 -a $backup_status = 2 ]; then 
  213.     increment_backup_level_1 
  214.     backup_status=$? 
  215. fi 
  216. # ############Today‘s database backup information########## 
  217. # check today‘s backup status # 
  218. check_backup=`ls -l --full-time $backup_dir/ | egrep -i "increment_db_|full_db_" | awk ‘{print $6}‘ | grep -i $today_backup | wc -l` 
  219. # check today‘s controlfile backup information # 
  220. control_file=`ls -lt --full-time $controlfile_dir/ | grep -i "c-*" | grep -i $today_backup | awk ‘{print $6 " " substr($7,1,8) " " $9}‘` 
  221. # check today‘s increment backup information # 
  222. backup_file_info=`ls -lt --full-time $backup_dir/ | egrep -i "increment_db_|full_db_" | grep -i $today_backup | awk ‘{print $6 " " substr($7,1,8) " " $9}‘` 
  223. log_file_info=`ls -lt --full-time $log/ | egrep -i "increment_db_|full_db_" | grep -i $today_backup | awk ‘{print $6 " " substr($7,1,8) " " $9}‘` 
  224. if [ "$1" = "all" ] ; then 
  225.     backup_file_info=`ls -lt --full-time $backup_dir/ | egrep -i "increment_db_|full_db" | awk ‘{print $6 " " substr($7,1,8) " " $9}‘` 
  226.     control_file=`ls -lt --full-time $controlfile_dir/ | grep -i "c-*"| awk ‘{print $6 " " substr($7,1,8) " " $9}‘` 
  227. fi 
  228.     
  229. # print today‘s backup information including controlfile and log information # 
  230. if [ $check_backup -ge 0 ]; then
  231.     if [ "$1" = "repeat" ] ; then 
  232.         repeat_increment_backup $1 
  233.     else 
  234.                 echo " ############Today‘s database backup information########## " 
  235.            if [ "$1" = "all" ]; then 
  236.     
  237.                     today_backup=`ls -l --full-time $backup_dir/ | grep -i full_db_* | awk ‘{print $6}‘` 
  238.             
  239.             echo "List date $purple ${today_backup[0]} $white level-0 backup database after file information" 
  240.            else 
  241.                 echo "Date $purple $today_backup $white database backup is completed." 
  242.                 fi 
  243.             echo "backup file directory: $backup_dir" 
  244.             echo "backup file information: $green" 
  245.         echo "" 
  246.         j=0 
  247.             for i in $backup_file_info 
  248.         do 
  249.             ((j++)) 
  250.             a[$j]=$i 
  251.             if [ $j = 3 ]; then 
  252.                 echo "${a[`expr $j - 2`]} ${a[`expr $j - 1`]} $backup_dir/${a[$j]}" 
  253.                  j=0 
  254.             fi 
  255.         done 
  256.             echo "$white" 
  257.                 echo "Controlfile information:$yellow" 
  258.         echo "" 
  259.         j=0 
  260.         for p in $control_file;do 
  261.             ((j++)) 
  262.             a[$j]=$p 
  263.             if [ $j = 3 ] ; then 
  264.                     echo "${a[`expr $j - 2`]} ${a[`expr $j - 1`]} $controlfile_dir/${a[$j]}" 
  265.                     j=0 
  266.             fi 
  267.           done 
  268.         echo "$white" 
  269.                 echo "log information:$blue" 
  270.         echo "" 
  271.         j=0 
  272.         for p in $log_file_info;do 
  273.             ((j++)) 
  274.             a[$j]=$p 
  275.             if [ $j = 3 ] ; then 
  276.                     echo "${a[`expr $j - 2`]} ${a[`expr $j - 1`]} $log/${a[$j]}" 
  277.                     j=0 
  278.             fi 
  279.           done 
  280.         echo "$white" 
  281.             echo "If you want increment backup database again,please use \"repeat\" parameter" 
  282.                 echo " ############Today database backup information the end ########## " 
  283.         fi 
  284. fi 
  285. # end print backup information # 
  286. # copy backup file # 
  287. if [ "$1" = "sync" ] ; then 
  288.     backup_status=9 
  289. fi 
  290. if [ "$backup_status" = 9 ]; then 
  291.     sync 
  292. else 
  293.      echo "Today‘s Backup file is synced. please check whether it‘s in the target database." 
  294.      echo "If you want to sync again,please use \"sync\" parameter." 
  295.      exit 0 
  296. fi 
  297. echo "If you want to view all backup information,Please use \"all\" parameter." 
  298. ) 2> $log/autobak_`date +‘%Y%m%d‘`.log 
  299. #mail -s "`date +‘%Y%m%d‘`database backup information" $mail_to_admin<$log/autobak_`date +‘%Y%m%d‘`.log
恢复脚本:
rman_restore_v1.1.sh

  1. #!/bin/sh
  2. export ORACLE_HOME=/opt/oracle11g/u01
  3. export ORACLE_SID=primary
  4. export LD_LIBRARY_PATH=${ORACLE_HOME}/lib:${ORACLE_HOME}/ctx/lib
  5. export PATH=$PATH:${ORACLE_HOME}/bin
  6. export NLS_LANG="American_america.zhs16gbk"
  7. export ORACLE_OWNER=oracle
  8. export backup_dir=/home/oracle/backup/backup
  9. export log=/home/oracle/backup/log
  10. rsync_dir=$backup_dir #sync dir
  11. controlfile_dir=$backup_dir/controlfile
  12. username=oracle #target OS ,oracle user 
  13. password=go2north #target oracle user password 
  14. target_host=172.16.5.27
  15. today_backup=`date +‘%Y-%m-%d‘`
  16. today=`date +‘%Y%m%d‘`
  17. white=$(echo -e "\e[39;40m")
  18. green=$(echo -e "\e[36;40m")
  19. red=$(echo -e "\e[31;40m")
  20. blue=$(echo -e "\e[33;40m")
  21. backup_status=2 #data backup status ,0: backup faild,1: 1 level increment backup,2 : 0 level backup
  22. # Begin change restore variable
  23. restore_status=true
  24. last_restore_file=increment_db_ORCL_76_663449691_1
  25. last_restore_date=(2008-08-22 19:36)
  26. last_recover_time="2008-08-28 15:12:08"
  27. last_restore_time=2
  28. last_restore_num=3
  29. # End change restore variable
  30. #sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/t=[0-9]\+/t=‘$((t+1))‘/‘ $0
  31. #sed -i ‘s/t=[0-9]\+/t=‘$((t+1))‘/‘ $0
  32. restore_file=`ls -lt --full-time $backup_dir/ | grep -i ‘increment_db_*‘ | awk ‘{print $9}‘|head -1`
  33. controlfile=`ls -lt --full-time $controlfile_dir | grep -i ‘c-*‘ | awk ‘{print $9}‘| head -1`
  34. recover_time=`ls -lt --full-time $backup_dir/ | grep -i ‘increment_db_*‘ | awk ‘{print substr($7,1,5)}‘| head -1`
  35. recover_date=(`ls -lt --full-time $backup_dir/ | grep -i ‘increment_db_*‘ | awk ‘{print $6 " " substr($7,1,5)}‘ | head -1`)
  36. recover_times=`date +‘%Y-%m-%d %H:%M:%S‘`
  37. function update_backup_info()
  38. {
  39.     sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/restore_status=.*/restore_status=true/‘ $0
  40.         sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/last_restore_file=.*/last_restore_file=‘"${restore_file}"‘/‘ $0
  41.         sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/last_recover_time=.*/last_recover_time=‘"\"${recover_times}\""‘/‘ $0
  42.                 sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/last_restore_date=.*/last_restore_date=‘"(${recover_date[*]})"/ $0
  43.         sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/last_restore_time=.*/last_restore_time=‘$((last_restore_time+1))‘/‘ $0
  44.         sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/last_restore_num=.*/last_restore_num=‘$((last_restore_num+1))‘/‘ $0
  45. }
  46. function restore_database() 
  47. {
  48.     echo "************* recover database start ****************"
  49.         cat << EOF | $ORACLE_HOME/bin/sqlplus ‘/as sysdba‘
  50.         shutdown immediate;
  51.         startup nomount;
  52. EOF
  53.         cat << EOF | $ORACLE_HOME/bin/rman target / |tee $log/rman_restore_db_`date +‘%y%m%d%H%M‘`.log
  54.         run {
  55.             allocate channel c01 type disk;
  56.             allocate channel c02 type disk;
  57.             allocate channel c03 type disk;
  58.             restore controlfile from "$controlfile_dir/$controlfile"; 
  59.             alter database mount;
  60.             recover database;
  61.             release channel c01;
  62.             release channel c02;
  63.             release channel c03;
  64.         }
  65.         alter database open resetlogs;
  66. EOF
  67.         if [ "$?" = 0 ];then 
  68.             echo "*******************restore be completed!************************"
  69.             backup_status=9
  70.             update_backup_info
  71.             exit 0
  72.         else
  73.             echo "******************restore database failed,please contact oracle dba*******"
  74.                         sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/last_recover_time=.*/last_recover_time=‘"\"${recover_times}\""‘/‘ $0
  75.             sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/restore_status=.*/restore_status=false/‘ $0
  76.         fi
  77.             return "$backup_status"
  78. }
  79. #delete backup file on the weekend again
  80. #file_info=`ls -l $backup_dir/ | grep -i ‘increment_backup_*.gz‘|wc -l`
  81. #if [ $file_count -gt 7 ]
  82. #then
  83. # del_files=`ls -lR $backup_dir| egrep -i "increment_db_|full_db_"|grep \`date -d "7 days ago" +‘%Y-%m-%d‘\`|awk "{print $9}"`
  84. # rm -f $del_files;
  85. # if [ $? = 0 ]
  86. # then
  87. # echo "removing $del_files"
  88. # fi
  89. #else
  90. # echo "No last file"
  91. #
  92. #fi
  93. ###########################################
  94. if [ "$last_restore_file" != "$restore_file" -o "${last_restore_date[1]}" != "$recover_time" ]; then 
  95. restore_database    
  96. fi
  97. if [ "$1" = "repeat" ] ; then
  98.                restore_database
  99. fi 
  100. if [ "$restore_status" = "true" -o "${last_restore_date[0]}" = ${recover_date[0]} ]; then 
  101. echo "Today‘s sync already completed!"
  102. echo "Last restore file: $backup_dir/$last_restore_file"
  103. echo "Last restore time: $last_restore_time"
  104. echo "The number of times the database be restored today: $last_restore_num"
  105. echo "The total number of times the database have ever been restore: $last_recover_time"
  106. sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/last_recover_time=.*/last_recover_time=‘"\"${recover_times}\""‘/‘ $0
  107. else
  108. sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/last_restore_time=.*/last_restore_time=0/‘ $0
  109. sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/restore_status=.*/restore_status=false/‘ $0
  110. sed -i ‘/^# Begin change restore variable/,/^# End change restore variable/s/last_recover_time=.*/last_recover_time=‘"\"${recover_times}\""‘/‘ $0
  111. fi

使用 RMAN 同步数据库

标签:

人气教程排行