Oracle資料庫的自動匯出備份指令碼(windows環境)

來源:互聯網
上載者:User
  1. 轉自Oracle資料庫的自動匯出備份指令碼(windows環境)
    由於winrar收費,修改了下指令碼使用7zip進行壓縮處理
  2. @echo off  
  3. @echo ===========================================================================   
  4. @echo Oracle資料庫的自動匯出備份指令碼(windows環境)。   
  5. @echo 通過windows任務計劃 或 AT 命令設定自動執行。   
  6. @echo ===========================================================================   
  7.   
  8. @echo =========================================================================   
  9. @echo Oracle資料庫的自動匯出備份指令碼(windows環境)。   
  10. @echo  說明:啟動備份時,需要配置以下變數   
  11. @echo    1、BACKUP_DIR           指定要備份到哪個中間目錄,壓縮完成後將被移動到BACKUP_WAREHOUSE目錄下   
  12. @echo    2、BACKUP_WAREHOUSE     指定曆史備份資料(壓縮後的)及日誌的存放位置   
  13. @echo    3、ORACLE_USERNAME      指定備份所用的Oracle使用者名稱   
  14. @echo    4、ORACLE_PASSWORD      指定備份所用的Oracle密碼   
  15. @echo    5、ORACLE_DB            指定備份所用的Oracle服務名   
  16. @echo    6、BACK_OPTION          備份選項,可以為空白,可以為full=y,可以為owner=a使用者,b使用者 或 TABLES=() 等等....   
  17. @echo    7、RAR_CMD              指定RAR命令列壓縮公用程式所在目錄   
  18. @echo    8、ZIP_CMD             指定7ZIP命令列壓縮公用程式所在目錄(開源免費)    
  19. @echo =========================================================================   
  20.   
  21. @echo ======================================================   
  22. @echo 備份資料庫服務資料   
  23. @echo ======================================================   
  24.   
  25. rem 以下變數需要根據實際情況配置   
  26. set BACKUP_DIR=D:/proj/dbbackup   
  27. set BACKUP_WAREHOUSE=D:/proj/dbbackup/file   
  28. set ORACLE_USERNAME=user  
  29. set ORACLE_PASSWORD=pwd   
  30. set ORACLE_DB=tnsname   
  31. set BACK_OPTION="owner=user"  
  32. set RAR_CMD="C:/Program Files (x86)/WinRAR/WinRAR.exe"  
  33. set ZIP_CMD="C:/Program Files (x86)/7-Zip/7z.exe"  
  34.   
  35. for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a   
  36. REM 如果檔案名稱中需要小時及分鐘,用下面第一行語句   
  37. REM set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%時%time:~3,2%分)_   
  38. set BACK_NAME=%ORACLE_DB%_%ORACLE_USERNAME%_%TODAY%   
  39. set BACK_FULL_NAME=%BACKUP_DIR%/%BACK_NAME%   
  40.   
  41.   
  42. REM 將操作記入批處理日誌 %BACK_FULL_NAME%_bat.log   
  43.   
  44. echo ==================備份資料庫服務資料================= >>%BACK_FULL_NAME%_bat.log   
  45. echo 備份開始...... >>%BACK_FULL_NAME%_bat.log   
  46. echo 當前的時間是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  47.   
  48.   
  49. exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% grants=Y %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%_exp.log"  
  50.   
  51.   
  52. if not exist %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC (md %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC)   
  53.   
  54. echo 壓縮並刪除原有dmp檔案...... >>%BACK_FULL_NAME%_bat.log   
  55. echo 當前的時間是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  56.   
  57. REM 使用7ZIP壓縮,注釋掉WINRAR命令部分   
  58. REM %RAR_CMD% a -df "%BACK_NAME%_logic.rar" "%BACK_FULL_NAME%.dmp"  
  59. %ZIP_CMD% a -tzip "%BACK_NAME%_logic.zip" "%BACK_FULL_NAME%.dmp"  
  60. rem 刪除源檔案   
  61. del "%BACK_FULL_NAME%.dmp"  
  62.   
  63. echo "%BACK_FULL_NAME%exp.log"  
  64. echo 壓縮並刪除原有dmp檔案結束! >>%BACK_FULL_NAME%_bat.log   
  65. echo 當前的時間是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  66.   
  67. echo 開始移動檔案...... >>%BACK_FULL_NAME%_bat.log   
  68. echo 當前的時間是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  69.   
  70. rem 使用7ZIP壓縮,注釋掉WINRAR命令部分   
  71. rem move %BACKUP_DIR%/*.rar %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC/   
  72. move %BACKUP_DIR%/*.zip %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC/   
  73.   
  74. echo 移動檔案完成! >>%BACK_FULL_NAME%_bat.log   
  75. echo 當前的時間是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  76.   
  77. REM net send %userdomain% "資料庫邏輯備份已於:%DATE% %time% 完成!"  
  78.   
  79. echo .   
  80. echo 備份完成!!! >>%BACK_FULL_NAME%_bat.log   
  81. echo 當前的時間是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  82. echo ===============備份資料庫服務資料完成!!!============== >>%BACK_FULL_NAME%_bat.log   
  83. move %BACKUP_DIR%/*.log %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC/   
  84. echo .  
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.