ORACLE常用定時備份指令碼
[oracle@rac1 ~]$ crontab -l
0 13 * * * /home/oracle/dumpfile/datapump_exp.sh
0 6 * * * /home/oracle/auto_clear_archivelog/auto_clear_archivelog.sh
0 */3 * * * /home/oracle/auto_clear_archivelog/ auto_purge_recyclebin.sh
30 2 * * * /home/oracle/rman_backup/scripts/backup.sh
50 7 * * * /home/oracle/rman_backup/scripts/backup_archivelog.sh
1、資料庫全庫匯出指令碼
[oracle@rac1 dumpfile]$ cat datapump_exp.sh
#!/bin/sh export MYDIR=/home/oracle/dumpfile export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK export ORACLE_SID=prod1 export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1 export PATH=$PATH:$ORACLE_HOME/bin export TNS_ADMIN=$ORACLE_HOME/network/admin export DAY_FORMAT=`date +'%Y%m%d%H%M'` ( cd $MYDIR echo "###################################################################################" echo "`date` removing old files..." 2>&1; find . -mtime +5 -name "prod_*.dmp" -exec rm -rf {} \; find . -mtime +5 -name "prod_*.log" -exec rm -rf {} \; echo "`date` removed" 2>&1 echo "`date` exporting fully ..." 2>&1 expdp \'sys/oracle@prod1 as sysdba\' DIRECTORY=MYDIR DUMPFILE=prod_${DAY_FORMAT}_%U.dmp LOGFILE=budget_${DAY_FORMAT}.log FULL=Y PARALLEL=8 COMPRESSION=ALL CLUSTER=N JOB_NAME=prod_exp_${DAY_FORMAT} 1>/dev/null 2>&1 echo "`date` export done" 2>&1 )>>$MYDIR/expdp.log
注意前提:
新建邏輯目錄,並在作業系統層面oracle使用者建立對應的資料夾
[oracle@rac1:/home/oracle]$sqlplus / as sysdba SQL> create directory MYDIR AS '/home/oracle/dumpfile';
針對sys/oracle@prod1 as sysdba中的prod1 tnsping測試ok 我這裡是rac環境,在tnsnames.ora配置了prod1
2、資料庫備份指令碼
[oracle@rac1:/home/oracle/rman_backup/scripts]$cat backup_sh
#!/bin/bash RMAN_BACKUP_DIR=/home/oracle/rman_backup export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK export ORACLE_SID=prod1 export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1 export PATH=$PATH:$ORACLE_HOME/bin export TNS_ADMIN=$ORACLE_HOME/network/admin export MAXPIECESIZE=32G export INCR_LEVEL=$((0)) export day=`date +%w` export DAY_DATE=`date +'%Y%m%d'` export DAY_FORMAT=`date +'%Y%m%d%H%M%S'` export TAG_NAME=TAG_Incr${INCR_LEVEL}_${DAY_FORMAT} echo "-----doing!!-----" >> $RMAN_BACKUP_DIR/rman_backup_log.log rman log=$RMAN_BACKUP_DIR/rman_backup_log.log <<EOF connect target / run { allocate channel 'ch1' TYPE DISK maxpiecesize=${MAXPIECESIZE}; allocate channel 'ch2' TYPE DISK maxpiecesize=${MAXPIECESIZE}; backup incremental level ${INCR_LEVEL} database tag ${TAG_NAME} format '${RMAN_BACKUP_DIR}/${ORACLE_SID}_${DAY_DATE}_db_%U'; sql 'alter system archive log current'; backup archivelog all format '${RMAN_BACKUP_DIR}/${ORACLE_SID}_${DAY_DATE}_arc_%U'; backup current controlfile format '${RMAN_BACKUP_DIR}/${ORACLE_SID}_${DAY_DATE}_ctl_%U'; release channel ch1; release channel ch2; } exit; EOF echo `date '+%Y-%m-%d %H:%M:%S'` >> $RMAN_BACKUP_DIR/rman_backup_log.log echo "-----done!!-----" >> $RMAN_BACKUP_DIR/rman_backup_log.log cat $RMAN_BACKUP_DIR/rman_backup_log.log >> $RMAN_BACKUP_DIR/rman_backup_history.log cd $RMAN_BACKUP_DIR find . -mtime +7 -name "prod1_*" -exec rm -rf {} \;
3、歸檔日誌備份指令碼
[oracle@rac1:/home/oracle/auto_clear_archivelog]$cat auto_clear_archivelog.sh
#!/bin/sh LOG_DIR=/home/oracle/auto_clear_archivelog export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK export ORACLE_SID=prod1 export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1 export PATH=$PATH:$ORACLE_HOME/bin export TNS_ADMIN=$ORACLE_HOME/network/admin echo "-----doing!!-----" >> $LOG_DIR/rman_delete_archivelog.log rman log=$LOG_DIR/rman_delete_archivelog.log target / <<EOF delete force noprompt archivelog all completed before 'sysdate-2'; crosscheck archivelog all; delete noprompt expired archivelog all; exit; EOF echo `date '+%Y-%m-%d %H:%M:%S'` >> $LOG_DIR/rman_delete_archivelog.log echo "-----done!!-----" >> $LOG_DIR/rman_delete_archivelog.log cat $LOG_DIR/rman_delete_archivelog.log >> $LOG_DIR/delete_history.log
4、歸檔清理指令碼
[oracle@rac1:/home/oracle/auto_clear_archivelog]$cat auto_clear_archivelog.sh
#!/bin/sh LOG_DIR=/home/oracle/auto_clear_archivelog export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK export ORACLE_SID=prod1 export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1 export PATH=$PATH:$ORACLE_HOME/bin export TNS_ADMIN=$ORACLE_HOME/network/admin echo "-----doing!!-----" >> $LOG_DIR/rman_delete_archivelog.log rman log=$LOG_DIR/rman_delete_archivelog.log target / <<EOF delete force noprompt archivelog all completed before 'sysdate-2'; crosscheck archivelog all; delete noprompt expired archivelog all; exit; EOF echo `date '+%Y-%m-%d %H:%M:%S'` >> $LOG_DIR/rman_delete_archivelog.log echo "-----done!!-----" >> $LOG_DIR/rman_delete_archivelog.log cat $LOG_DIR/rman_delete_archivelog.log >> $LOG_DIR/delete_history.log
5、 參考指令碼,可根據需要更改
cat backup.sh_bak
#!/bin/bash RMAN_BACKUP_DIR=/home/oracle/rman_backup export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK export ORACLE_SID=prod1 export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1 export PATH=$PATH:$ORACLE_HOME/bin export TNS_ADMIN=$ORACLE_HOME/network/admin export MAXPIECESIZE=32G export INCR_LEVEL=$((0)) export day=`date +%w` if [ $day -eq 0 ] ; then INCR_LEVEL=$((0)) fi if [ $day -eq 1 ] ; then INCR_LEVEL=$((2)) fi if [ $day -eq 2 ] ; then INCR_LEVEL=$((2)) fi if [ $day -eq 3 ] ; then INCR_LEVEL=$((1)) fi if [ $day -eq 4 ] ; then INCR_LEVEL=$((2)) fi if [ $day -eq 5 ] ; then INCR_LEVEL=$((2)) fi if [ $day -eq 6 ] ; then INCR_LEVEL=$((1)) fi export DAY_DATE=`date +'%Y%m%d'` export DAY_FORMAT=`date +'%Y%m%d%H%M%S'` export TAG_NAME=TAG_Incr${INCR_LEVEL}_${DAY_FORMAT} echo "-----doing!!-----" >> $RMAN_BACKUP_DIR/rman_backup_log.log rman log=$RMAN_BACKUP_DIR/rman_backup_log.log <<EOF connect target / run { allocate channel 'ch1' TYPE DISK maxpiecesize=${MAXPIECESIZE}; allocate channel 'ch2' TYPE DISK maxpiecesize=${MAXPIECESIZE}; backup incremental level ${INCR_LEVEL} database tag ${TAG_NAME} format '${RMAN_BACKUP_DIR}/${ORACLE_SID}_${DAY_DATE}_db_%U'; sql 'alter system archive log current'; backup archivelog all format '${RMAN_BACKUP_DIR}/${ORACLE_SID}_${DAY_DATE}_arc_%U' delete input; backup current controlfile format '${RMAN_BACKUP_DIR}/${ORACLE_SID}_${DAY_DATE}_ctl_%U'; release channel ch1; release channel ch2; } exit; EOF echo `date '+%Y-%m-%d %H:%M:%S'` >> $RMAN_BACKUP_DIR/rman_backup_log.log echo "-----done!!-----" >> $RMAN_BACKUP_DIR/rman_backup_log.log cat $RMAN_BACKUP_DIR/rman_backup_log.log >> $RMAN_BACKUP_DIR/rman_backup_history.log cd $RMAN_BACKUP_DIR find . -mtime +7 -name "prod1_*" -exec rm -rf {} \;
6、清空oracle表空間回收站
cat auto_purge_recyclebin.sh
#!/bin/bash source ~/.bash_profile sqlplus -S /nolog > result.log<<EOF #set heading off feedback off pagesize 0 verify off echo off conn / as sysdba PURGE tablespace tbs_cc user cc; exit EOF
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70004783/viewspace-2792540/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 【DATAPUMP】Oracle資料泵定時備份刪除指令碼Oracle指令碼
- ORACLE備份指令碼Oracle指令碼
- Mysql定時備份資料指令碼MySql指令碼
- linux mysql定時備份指令碼記錄LinuxMySql指令碼
- oracle自動冷備份指令碼Oracle指令碼
- 分享Oracle Rman的備份指令碼Oracle指令碼
- oracle資料庫使用rman備份指令碼Oracle資料庫指令碼
- 自動定時備份 mysql 資料庫 的 shell 指令碼MySql資料庫指令碼
- 備份指令碼指令碼
- rman 備份指令碼指令碼
- mysql備份指令碼MySql指令碼
- mysql容器的定時備份指令碼,有二種方法,備份好後打包傳送到遠端備份主機MySql指令碼
- 基於Linux指令碼,對日誌進行定時壓縮備份Linux指令碼
- 自動備份指令碼指令碼
- windows mysqldump備份指令碼WindowsMySql指令碼
- MySQL 定時備份MySql
- expdp 邏輯備份指令碼指令碼
- 資料庫備份指令碼資料庫指令碼
- 兩套mysql備份指令碼MySql指令碼
- MySQL 定時增量備份MySql
- MYSQL定時備份(一)MySql
- ORACLE NBU調取oracle rman指令碼備份歸檔不自動刪除歸檔Oracle指令碼
- MySQL中binlog備份指令碼分享MySql指令碼
- 使用shell 指令碼備份資料指令碼
- 檢查備份情況的指令碼指令碼
- 【MySQL】Xtrabackup備份及恢復指令碼MySql指令碼
- MySQL:Windows下分庫備份指令碼MySqlWindows指令碼
- windows 全量+增量備份指令碼batWindows指令碼BAT
- MYSQL定時任務-定時清除備份資料MySql
- oracle_ray.sh 常用的oracle sql功能指令碼OracleSQL指令碼
- linux啟定時指令碼Linux指令碼
- 定時備份MySQL資料庫MySql資料庫
- mysqldump壓縮備份匯出匯入(含定期備份shell指令碼)MySql指令碼
- ADB常用指令備忘
- ORACLE 備份表Oracle
- MySQL資料庫備份的shell指令碼MySql資料庫指令碼
- windows 批處理備份目錄指令碼Windows指令碼
- MySQL備份指令碼,應該這麼寫MySql指令碼