阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

通过shell脚本实现对Oracle RMAN备份集压缩并异地备份

230次阅读
没有评论

共计 1367 个字符,预计需要花费 4 分钟才能阅读完成。

1、背景说明

公司磁带库坏了。每天 Oracle 的备份往哪里放?

2、备份方式重新规划

原备份方式

通过 shell 脚本实现对 Oracle RMAN 备份集压缩并异地备份

 

 

现备份方式

通过 shell 脚本实现对 Oracle RMAN 备份集压缩并异地备份

 

 

3、备份脚本分享

小白写了一个备份的 shell 脚本,分享出来

#!/bin/bash
# tar oraclebackup file  

# check RMAN is run?
#我做 RMAN 备份的时候都会创建一个 RMAN 日志,所以此日志就可以判断我的 RMAN 是否执行了
filename="/mnt/rman/log/RmanBackup_`date +%y%m%d`.log"  
comparedata="Recovery Manager complete."

if [-e $filename];then
    echo "`date` RMAN is run" &>> /OPS/tarlog
else
    echo "`date` RMAN is not run,please check" &>> /OPS/tarlog
    exit 1
fi

# check RMAN is OK?
#通过判断我的日志最后结果,判断 RMAN 备份是否成功,如果没有成功,我也没必要备份了
data=`tail -1 $filename`
if ["$data" == "$comparedata"];then
    echo "`date` Rman backup sucess" &>> /OPS/tarlog
else
    echo "`date` Rman backup fail" &>> /OPS/tarlog
    exit 2
fi

# tar backupfile and move to backupserver
#将当天的备份集压缩备份出来并 move 至对应 nfs 提供的文件夹,我 300GB 的备份压缩后只要 30 个 G,压缩比还是很惊人的
/usr/bin/find /mnt/rman -name 'oradb1*' > /OPS/tarlist
for i in `/bin/cat /OPS/tarlist`;do
    echo "`date` tar $i start" &>> /OPS/tarlog
    tar -zcvf $i.tar.gz $i &>> /OPS/tarlog 
done

if [$? -eq 0];then
    echo "`date` tar end success" &>> /OPS/tarlog
    mv /mnt/rman/*.tar.gz /oraclebackup
    if [$? -eq 0];then
        echo "`date` move to oraclebackup end success" &>> /OPS/tarlog
    else
        echo "`date` move to oraclebackup fail" &>> /OPS/tarlog
    fi

else
    echo "`date` tar fail" &>> /OPS/tarlog
fi

更多 Oracle 相关信息见 Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-04/142745.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计1367字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中