将Oracle自动备份脚本加入到定时任务

date=`date +%Y_%m_%d_%H_%M_%S`   #获取系统当前日期时间

days=7  #设置删除7天之前的备份文件

orsid=`127.0.0.1:1521/orcl`  #Oracle数据库服务器IP、端口、SID

orowner=gg  #备份此用户下面的数据

bakuser=gg  #用此用户来执行备份,必须要有备份操作的权限

bakpass=gg  #执行备注的用户密码

bakdir=/home/oracleBackup  #备份文件路径,需要提前创建好

bakdata=$orowner"_"$date.dmp #备份数据库名称

baklog=$orowner"_"$date.log #备份执行时候生成的日志文件名称

ordatabak=$orowner"_"$date.tar.gz #最后保存的Oracle数据库备份文件

cd $bakdir #进入备份目录

mkdir -p $orowner #按需要备份的Oracle用户创建目录

cd $orowner #进入目录

exp $bakuser/$bakpass@$orsid grants=y owner=$orowner file=$bakdir/$orowner/$bakdata log=$bakdir/$orowner/$baklog #执行备份

tar -zcvf $ordatabak $bakdata  $baklog  #压缩备份文件和日志文件

#find $bakdir/$orowner  -type f -name "*.log" -exec rm {} \; #删除备份文件

#find $bakdir/$orowner  -type f -name "*.dmp" -exec rm {} \; #删除日志文件

find $bakdir/$orowner  -type f -name "*.tar.gz" -mtime +$days -exec rm -rf {} \;  #删除7天前的备份(注意:{} \中间有空格)

添加脚本执行权限

chmod +x /home/oracleBackup/ordatabak.sh

*/2 * * * * /home/oracleBackup/ordatabak.sh >>/home/oracleBackup/back.log

1.每两分钟执行一次

2.日志好像没什么作用,执行后日志里面是空的

3.用Oracle用户执行,不然会报错

参考:

https://www.osyunwei.com/archives/5960.html

猜你喜欢

转载自blog.csdn.net/dan47645/article/details/86674977