程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> 關於Oracle數據庫 >> Linux 自動備份oracle數據庫詳解

Linux 自動備份oracle數據庫詳解

編輯:關於Oracle數據庫

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用來運行每三個月份運行指定任務。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved