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用户执行,不然会报错
参考: