DG环境数据库RMAN备份策略制定:

主库(Primary)

备库(Standby)

引用说明

主库(Primary)

$ crontab -l
```
0 1 * * * /bin/bash /usr2/backupsh/full_backup.rman
0 */2 * * * /bin/bash /usr2/backupsh/arch_backup.rman
0 3 * * * /bin/bash /usr2/backupsh/del_old.sh
```

全库备份

more /usr2/backupsh/full_backup.rman
```
#!/bin/bash
#Make sure your bkdir and change it!
bkdir=/usr2/BACKUP
foldername=`date +%Y%m%d`
mkdir -p $bkdir
cd $bkdir
if [ -d $foldername ]
then
echo 'go on'
else
echo 'need mkdir'
mkdir $foldername
fi

oracle environment

export ORACLE_SID=jyzhao

export ORACLE_BASE=/opt/app/oracle

export ORACLE_HOME=/opt/app/oracle/product/11.2.0/db_1

export PATH=$PATH:$ORACLE_HOME/bin:$HOME/bin

export LD_LIBRARY_PATH=$ORACLE_HOME/lib

export NLS_LANG="simplified chinese_china.ZHS16GBK"

export NLS_DATE_FORMAT="YYYY-MM-DD HH24:Mi:SS"

rman target / log=$bkdir/$foldername/LOG_full_$foldername.log <<EOF

run{

configure retention policy to recovery window of 5 days;

configure controlfile autobackup on;

configure controlfile autobackup format for device type disk to '$bkdir/$foldername/controlfile%F';

CONFIGURE ARCHIVELOG DELETION POLICY TO APPLIED ON ALL STANDBY;

allocate channel c1 device type disk;

allocate channel c2 device type disk;

allocate channel c3 device type disk;

allocate channel c4 device type disk;

backup database skip inaccessible

backup incremental level=0 database

format '$bkdir/$foldername/full_BACK_%U';

release channel c1;

release channel c2;

release channel c3;

release channel c4;

}

allocate channel for maintenance device type disk;

crosscheck backupset;

delete noprompt expired backupset;

delete noprompt obsolete;

exit

EOF

<h2 id='1.2'> 归档备份 </h2>
more /usr2/backupsh/arch_backup.rman

!/bin/bash

Make sure your bkdir and change it!

bkdir=/usr2/BACKUP

foldername=date +%Y%m%d

mkdir -p $bkdir

cd $bkdir

if [ -d $foldername ]

then

echo 'go on'

else

echo 'need mkdir'

mkdir $foldername

fi

oracle environment

export ORACLE_SID=jyzhao

export ORACLE_BASE=/opt/app/oracle

export ORACLE_HOME=/opt/app/oracle/product/11.2.0/db_1

export PATH=$PATH:$ORACLE_HOME/bin:$HOME/bin

export LD_LIBRARY_PATH=$ORACLE_HOME/lib

export NLS_LANG="simplified chinese_china.ZHS16GBK"

export NLS_DATE_FORMAT="YYYY-MM-DD HH24:Mi:SS"

rman target / log=$bkdir/$foldername/LOG_arch_$foldername.log append <<EOF

run{

configure retention policy to recovery window of 5 days;

configure controlfile autobackup on;

configure controlfile autobackup format for device type disk to '$bkdir/$foldername/controlfile%F';

CONFIGURE ARCHIVELOG DELETION POLICY TO APPLIED ON ALL STANDBY;

allocate channel c1 device type disk;

allocate channel c2 device type disk;

allocate channel c3 device type disk;

allocate channel c4 device type disk;

backup database skip inaccessible

backup archivelog all delete input

format '$bkdir/$foldername/arch_BACK_%U';

release channel c1;

release channel c2;

release channel c3;

release channel c4;

}

allocate channel for maintenance device type disk;

crosscheck backupset;

delete noprompt expired backupset;

delete noprompt obsolete;

exit

EOF


<h2 id='1.3'> 删除历史文件夹 </h2>
more /usr2/backupsh/del_old.sh

!/bin/bash

del old folders

Make sure your bkdir and change it!

bkdir=/usr2/BACKUP

cd $bkdir && find . -mtime +7 | xargs rm -rf

<h1 id='2'> 备库(Standby) </h1>
$ crontab -l

0 3 * * * /usr2/del_arch/del_arch.sh

<h2 id='2.1'> 删除归档 </h2>
more /usr2/del_arch/del_arch.sh

!/bin/bash

export ORACLE_SID=jyzhao_s

export ORACLE_HOME=/opt/app/oracle/product/11.2.0/db_1

export ARCHIVE_DIR=/usr2/oradata/archivelog

export LOG_FILE=/usr2/oradata/archivelog/del_archive.log

echo "开始删除归档日志:date……">>$LOG_FILE

if [ whoami != 'oracle' ]

then

echo "Error: You must be oracle to execute.">>$LOG_FILE

exit 99

fi

del_seq=ls -rt $ARCHIVE_DIR/ |grep -v JYZHAO_S| head -1|cut -f4 -d_|cut -f1 -d.

$ORACLE_HOME/bin/sqlplus -silent "/ as sysdba" <tmp.log

set pagesize 0 feedback off verify off heading off echo off

select max(sequence#) from v$ARCHIVED_LOG where APPLIED='YES';

exit;

XFF

max_sn=cat tmp.log

rm tmp.log

max_sn=$(( $max_sn - 20 ))

我这里是保留最近的20个归档文件,这个具体情况自己决定

while [[ ${del_seq} -lt ${max_sn} ]]

do

echo "${ARCHIVE_DIR}/arch_874084675_1_${del_seq}.arc">>$LOG_FILE

rm ${ARCHIVE_DIR}/arch_874084675_1_${del_seq}.arc

这里是我定义归档文件的格式,具体根据自己的归档文件格式来匹配,关键是匹配日志的sequence no。

del_seq=$(( $del_seq + 1 ))

done

echo "删除归档日志结束:date……">>$LOG_FILE

清楚controlfile中信息

$ORACLE_HOME/bin/rman target / <>$LOG_FILE

crosscheck archivelog all;

delete expired archivelog all;

YES

exit;

XIFENFEI

echo "………………………………………………………………………………………………………………………">>$LOG_FILE


<h1 id='3'> 引用说明 </h1>
备库删除归档的脚本参考于惜分飞的博客,原地址如下:
[http://www.xifenfei.com/1144.html](http://www.xifenfei.com/1144.html)
原文说到重点是在读取现在存在的归档日志文件中sequence最小值时,
使用了`ls -tr $ARCHIVE_DIR/|grep -v stdarch | head -1|cut -f2 -d_`
而我这里就根据实际情况改成:`ls -rt $ARCHIVE_DIR/ |grep -v JYZHAO_S| head -1|cut -f4 -d_|cut -f1 -d.`

DG环境数据库RMAN备份策略制定的更多相关文章

  1. 记录一则RMAN备份策略修正案例

    背景:在给某客户处理问题时,发现客户数据库的备份空间即将用尽,进一步查看发现是用户数据库的当前RMAN备份策略存在潜在问题,需要修改备份策略. 环境:SunOS 5.10 + Oracle 11.2. ...

  2. 生产环境提升rman备份速度----启动块跟踪

    生产环境提升rman备份速度----启动块跟踪 [环境] AIX(5300-08).oracle10g(10.2.0.1.0-64bit) [目标] 因为生产环境数据量较大,欲加快rman备份的速度 ...

  3. RMAN备份策略与异机恢复一例(续篇)

    本文是<RMAN备份策略与异机恢复一例>的续篇,继续实验验证,最终实现两个需求: 1.异机恢复临时测试的小库 2.传输归档时,实现增量传输 1.异机恢复临时测试的小库 之前异机恢复的需求已 ...

  4. RMAN备份策略与异机恢复一例

    实验环境: A机器(生产用途):RHEL 6.5 + Oracle 11.2.0.4 + IP Address 192.168.1.11 B机器(备机用途):RHEL 6.5 + Oracle 11. ...

  5. Oracle RMAN备份策略

    建立增量备份:如果数据库运行于不归档模式下,只能在数据库干净关闭的情况下 ( 以 normal .immediate . transactional 方式关闭 ) 才能进行一致性的增量备份,如果数据库 ...

  6. oracle数据库rman备份计划及恢复

    1.rman完全恢复的前提条件:历史的datafile,controlfile和spfile备份,加上完整的archivelog和完好的redolog. 2.rman备份脚本: a.RMAN 0级备份 ...

  7. 【Oracle】Rman备份策略

    1. 查看可设置参数 RMAN> show all; RMAN configuration parameters for database with db_unique_name DRZ are ...

  8. oracle数据库rman备份与还原

    我是oracle 界的小白,由于公司领导要求,不得不硬着头皮在网上找rman备份还原的方法,废话不多说,具体看例子(window) 运行CMD: rman target 管理员账号/密码@orcl 备 ...

  9. Oracle RAC 实验环境RMAN备份v1.01

    Oracle RAC 实验环境RMAN备份v1.01 环境:RHEL 6.5 + Oracle GI 11.2.0.4 + RAC 11.2.0.4 (2 nodes) 需求:制定RAMN备份策略 版 ...

随机推荐

  1. HDU---BigZhuGod的粉丝

    Problem Description 真正的粉丝,是不需要题目描述的^_^.   Input 第一行输入数据组数T(1≤T≤100).接下来T行,每行一个有格式的字符串,详见样例,字符串长度不超过1 ...

  2. 使用canvas绘制一个时钟

    周末学习canvas的一些基础功能,顺带写了一个基础的时钟.现在加工一下,做的更好看一点,先放上效果图: 谈一些自己的理解: (1).要绘制一个新的样式(不想被其他样式影响,或者影响到其他样式),那么 ...

  3. ThinkPHP5 助手函数

    对于ThinkPHP5.0以前的版本,助手函数全部是单字母函数,但到ThinkPHP5之后,使用如下函数来代替单字母函数: 最常用: /** * 实例化Model * @param string $n ...

  4. extern用法总结

    在C语言中,修饰符extern用在变量或者函数的声明前,用来说明"此变量/函数是在别处定义的,要在此处引用".1. extern修饰变量的声明. 如果文件a.c需要引用b.c中变量 ...

  5. GDB调试汇编分析

    GDB调试汇编分析 代码 本次实践我参照了许多先做了的同学的博客,有卢肖明,高其,张梓靖同学.代码借用的是卢肖明同学的代码进行调试运行. GCC编译 使用gcc -g gdbtest.c -o gdb ...

  6. android——fargment基础

    1.Fragment的产生与介绍 Android运行在各种各样的设备中,有小屏幕的手机,超大屏的平板甚至电视.针对屏幕尺寸的差距,很多情况下,都是先针对手机开发一套App,然后拷贝一份,修改布局以适应 ...

  7. java 遍历arrayList的四种方法

    package com.test; import java.util.ArrayList;import java.util.Iterator;import java.util.List; public ...

  8. ExtJS扩展:扩展grid之toolbar button禁用表达式

          在前一篇文章我们扩展了grid通过选中记录数来禁用toolbar上的按钮,有时候我们需要通过记录中的数据来决定是否禁用按钮,今天我们就来扩展它.       照例,最新的代码和例子都在gi ...

  9. MySQL 处理插入过程中的主键唯一键重复值办法

    200 ? "200px" : this.width)!important;} --> 介绍 本篇文章主要介绍在插入数据到表中遇到键重复避免插入重复值的处理方法,主要涉及到I ...

  10. C#+OpenGL+FreeType显示3D文字(1) - 从TTF文件导出字形贴图

    C#+OpenGL+FreeType显示3D文字(1) - 从TTF文件导出字形贴图 +BIT祝威+悄悄在此留下版了个权的信息说: 最近需要用OpenGL绘制文字,这是个很费时费力的事.一般的思路就是 ...