Linux 自動備份oracle資料庫詳解_oracle

來源:互聯網
上載者:User

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

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.