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 可以根據需要使用expdp exp scott/tiger@orcl file="$FILENAME ".dmp log="$FILENAME".log owner=scott rows=y #打包+加壓 cd .. tar -cf $FILENAME.tar $FILENAME rm -rf $FILENAME gzip $FILENAME.tar exit EOF
步驟二、使用定時腳本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用來運行每三個月份運行指定任務。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!