(转)Oracle数据库的⾃动导出备份脚本(windows环境)
1. 转⾃
由于winrar收费,修改了下脚本使⽤7zip进⾏压缩处理
2. @echo off
3. @echo ===========================================================================
4. @echo Oracle数据库的⾃动导出备份脚本(windows环境)。
5. @echo 通过windows任务计划或AT命令设置⾃动执⾏。
oracle数据库自动备份方法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)/"
33. set ZIP_CMD="C:/Program Files (x86)/"
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 .
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论