Linux 自動備份oracle數據:
曾經有個同事,來回操作開發和生產的數據庫,結果誤刪了生產的數據庫,那種心情我想不是一般人能理解的,雖然說oracle可以有方法還原,但并不是徹底的。
所以,在工作中,不管是開發還是維護,備份數據庫是非常有必要。
簡單實用的晚間自動備份數據庫小案例
步驟一、創建備份腳本,暫且命名為orabak.sh
#路徑名,指定備份的路徑FILEPATH = /oracle/orabak#根據指定日期格式,定義備份數據庫文件名FILENAME = `date + %Y%m%d_%H%M#切換至指定路徑,并創建文件夾cd $FILEPATH mkdir $FILENAME chmod 775 $FILENAME#oracle變量設置export USER=oracle;export ORACLE_SID=orcl;export ORACLE_HOME=/oracle/app/oracle/product/11.2.0/dbhome_1;export PATH=$ORACLE_HOME/bin:$PATH;#導出數據庫 這里使用了exp 可以根據需要使用expdpexp scott/tiger@orcl file="$FILENAME ".dmp log="$FILENAME".log owner=scott rows=y#打包+加壓cd ..tar -cf $FILENAME.tar $FILENAMErm -rf $FILENAMEgzip $FILENAME.tarexitEOF
步驟二、使用定時腳本crontab自動調用備份腳本
linux/aix 使用crontab -e命令,再最后一行加入改功能腳本,例如:
10 12 * * * sh /oracle/orabak/orabak.sh
關于linux下crontab的使用
minute hour day month dayofweek command
minute - 從0到59的整數
hour - 從0到23的整數
day - 從1到31的整數 (必須是指定月份的有效日期)
month - 從1到12的整數 (或如Jan或Feb簡寫的月份)
dayofweek - 從0到7的整數,0或7用來描述周日 (或用Sun或Mon簡寫來表示)
command - 需要執行的命令(可用as ls /proc >> /tmp/proc或 執行自定義腳本的命令)
對于以上各語句,星號(*)表示所有可用的值。例如*在指代month時表示每月執行(需要符合其他限制條件)該命令。
整數間的連字號(-)表示整數列,例如1-4意思是整數1,2,3,4
指定數值由逗號分開。如:3,4,6,8表示這四個指定整數。
符號“/”指定步進設置。“/”表示步進值。如0-59/2定義每兩分鐘執行一次。步進值也可用星號表示。如*/3用來運行每三個月份運行指定任務。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
新聞熱點
疑難解答