linux下 oracle rman简单备份&上传ftp&逻辑备份

-- rman
cd /home/oracle/scripts/
vim arcfull.sh
#!/bin/sh  
  
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1
export ORACLE_SID=XXX
export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin
days=7
BAKUPTIME=`date +%Y_%m_%d`
rman target / nocatalog cmdfile /home/oracle/scripts/archfullback.sh  log  /home/oracle/scripts/$BAKUPTIME.log


find /home/oracle/scripts  -type f -name "*.log" -mtime +$days -exec rm -rf {} \;

--其中archfullback.sh
RUN {
 DELETE FORCE NOPROMPT OBSOLETE DEVICE TYPE DISK;;
 crosscheck archivelog all;
 delete noprompt expired archivelog all;
 crosscheck backup;
 delete noprompt expired backup;
 allocate channel c1 type disk;
 allocate channel c2 type disk;
 backup database format 'db_%s_%p_%t' plus archivelog delete all input format 'arch_%s_%p_%t';
 release channel c1;
 release channel c2;
 }
exit

--ftpback.sh
#!/bin/bash
TODAY=`date +%Y_%m_%d`
cd XXX
tar -zcvf arcfull_%TODAY.tar.gz *
ftp -n  192.168.XXX.XXX << EOF
user user password
bin
lcd XXX
prompt
mput *.tar.gz
bye
EOF

-- 最后添加任务
crontab -e 
0 1 * * * /home/oracle/scripts/arcfull.sh


-- 附expdp备份
#!/bin/sh  
  
export ORACLE_BASE=/u01/app/oracle 
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1
export ORACLE_SID=XXX
export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin  
  
export DATA_DIR=/ora02/sdd2/expdpdir
export LOGS_DIR=/ora02/sdd2/expdpdir
export DELTIME=`date -d "10 days ago" +%Y%m%d`  
export BAKUPTIME=`date +%Y%m%d%H%M%S`  
  
  
echo "Starting bakup..."  
echo "Bakup file path $DATA_DIR/$BAKUPTIME.dmp"  
expdp system/*** directory=dump_dir full=y dumpfile=$BAKUPTIME.dmp  logfile=$BAKUPTIME.log

echo "Delete the file bakup before 10 days..."  
rm -rf $DATA_DIR/$DELTIME*.dmp  
rm -rf $LOGS_DIR/$DELTIME*.log  

RAC的一个参考备份例子:

#节点1:
#/bin/bash
source /home/oracle/.bash_profile
backtime=`date +%Y%m%d`
rman target /  log=/rmanbak/log/node1_backupall_$backtime.log <<EOF
allocate channel for maintenance type disk;
run{
allocate channel ch1 device type disk;
allocate channel ch2 device type disk;
backup database format '/rmanbak/datafile/rac1_%d_%T_%U';
backup archivelog all format '/rmanbak/datafile/rac1_arch_%t_%s_%c' delete input;
report obsolete;
delete force noprompt  obsolete device type disk;
crosscheck backup;
crosscheck archivelog all;
delete noprompt expired archivelog all;
delete noprompt expired backup;
release channel ch1;
release channel ch2;
}
EOF
echo "backup complete!"
scp /rmanbak/log/node1_backupall_$backtime.log oracle@rac2:/rmanbak/log/
exit

#节点2
#/bin/bash
source /home/oracle/.bash_profile
backtime=`date +%Y%m%d`
if [ -f /rmanbak/log/node1_backupall_$backtime.log ]
then
echo "node1 backup have been success!"
exit
else
echo "node1 backup have been filed,start node2 backup!"
fi
rman target /  log=/rmanbak/log/node2_backupall_$backtime.log <<EOF
allocate channel for maintenance type disk;
run{
allocate channel ch1 device type disk;
allocate channel ch2 device type disk;
backup database format '/rmanbak/datafile/rac2_%d_%T_%U';
backup archivelog all format '/rmanbak/datafile/rac2_arch_%t_%s_%c' delete input;
report obsolete;
delete force noprompt  obsolete device type disk;
crosscheck backup;
crosscheck archivelog all;
delete noprompt expired archivelog all;
delete noprompt expired backup;
release channel ch1;
release channel ch2;
}
EOF
echo "backup complete!"
exit

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

朝闻道-夕死可矣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值