现在的位置: 首页 > 综合 > 正文

data guard 归档管理 (standby)

2013年06月17日 ⁄ 综合 ⁄ 共 1089字 ⁄ 字号 评论关闭

# .bash_profile

### 这里是提取用户的变量

# Get the aliases and functions

if [ -f ~/.bashrc ]; then

        . ~/.bashrc

fi

 

# User specific environment and startup programs

 

PATH=$PATH:$HOME/bin

 

export PATH

export ORACLE_BASE=/opt/oracle

export ORACLE_HOME=/opt/oracle/product/10g

export ORACLE_SID=orcl

export LD_LIBRARY_PATH=$ORACLE_HOME/lib

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

 

export SHELL_DIR=/u01/scripts

 

 

 

del_seq=`ls /u01/arch/|head -1|cut -f2 -d_`

 

echo $del_seq

 

$ORACLE_HOME/bin/sqlplus -s "sys/oracle@orcl as sysdba" <<eof >/u01/scripts/max_sn.log

 

set head off;

 

set feedback;

 

select max(sequence#) from v\$archived_log where applied='YES';

## 这里我找出已经应用的最大归档文件  \$  转义了$ 

exit;

 

eof

 

max_sn=`cat /u01/scripts/max_sn.log|awk '{print $1}'|grep ^[0-9]`

 

max_sn=`expr $max_sn - 10`

 

## 我这里是保留最近的10个已经应用归档文件,这个具体情况自己决定

 

echo $max_sn

 

while [ $del_seq -lt $max_sn ]

 

do

 

  rm -f /u01/arch/1_"$del_seq"_732454468.dbf

 

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

 

  del_seq=`expr $del_seq + 1`

 

  echo $del_seq

 

done

 

 

 

## 脚本里的红色部分根据自己的情况进行修改

 

 

 

 本人是参考学习了http://blog.csdn.net/tianlesoftware/article/details/6194498 结合自己的实际情况。在此呼吁:所有的技术牛人都能在互联网上共享技术,让我们中国的IT技术越来越NB,我也会分享我的学习和经验。

抱歉!评论已关闭.