博客园  :: 首页  :: 新随笔  :: 联系 :: 管理
  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 .