设为首页 收藏本站
查看: 749|回复: 0

[经验分享] (转)Oracle数据库的自动导出备份脚本(windows环境)

[复制链接]
YunVN网友  发表于 2016-8-14 07:07:35 |阅读模式
转自Oracle数据库的自动导出备份脚本(windows环境)
由于winrar收费,修改了下脚本使用7zip进行压缩处理

@echo off
@echo ===========================================================================
@echo Oracle数据库的自动导出备份脚本(windows环境)。
@echo 通过windows任务计划 或 AT 命令设置自动执行。
@echo ===========================================================================
@echo =========================================================================
@echo Oracle数据库的自动导出备份脚本(windows环境)。
@echo  说明:启动备份时,需要配置以下变量
@echo    1、BACKUP_DIR           指定要备份到哪个中间目录,压缩完成后将被移动到BACKUP_WAREHOUSE目录下
@echo    2、BACKUP_WAREHOUSE     指定历史备份数据(压缩后的)及日志的存放位置
@echo    3、ORACLE_USERNAME      指定备份所用的Oracle用户名
@echo    4、ORACLE_PASSWORD      指定备份所用的Oracle密码
@echo    5、ORACLE_DB            指定备份所用的Oracle服务名
@echo    6、BACK_OPTION          备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 或 TABLES=() 等等....
@echo    7、RAR_CMD              指定RAR命令行压缩工具所在目录
@echo    8、ZIP_CMD             指定7ZIP命令行压缩工具所在目录(开源免费)
@echo =========================================================================
@echo ======================================================
@echo 备份数据库服务数据
@echo ======================================================
rem 以下变量需要根据实际情况配置
set BACKUP_DIR=D:\proj\dbbackup
set BACKUP_WAREHOUSE=D:\proj\dbbackup\file
set ORACLE_USERNAME=user
set ORACLE_PASSWORD=pwd
set ORACLE_DB=tnsname
set BACK_OPTION="owner=user"
set RAR_CMD="C:\Program Files (x86)\WinRAR\WinRAR.exe"
set ZIP_CMD="C:\Program Files (x86)\7-Zip\7z.exe"
for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a
REM 如果文件名中需要小时及分钟,用下面第一行语句
REM set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_
set BACK_NAME=%ORACLE_DB%_%ORACLE_USERNAME%_%TODAY%
set BACK_FULL_NAME=%BACKUP_DIR%\%BACK_NAME%

REM 将操作记入批处理日志 %BACK_FULL_NAME%_bat.log
echo ==================备份数据库服务数据================= >>%BACK_FULL_NAME%_bat.log
echo 备份开始...... >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log

exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% grants=Y %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%_exp.log"

if not exist %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC (md %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC)
echo 压缩并删除原有dmp文件...... >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
REM 使用7ZIP压缩,注释掉WINRAR命令部分
REM %RAR_CMD% a -df "%BACK_NAME%_logic.rar" "%BACK_FULL_NAME%.dmp"
%ZIP_CMD% a -tzip "%BACK_NAME%_logic.zip" "%BACK_FULL_NAME%.dmp"
rem 删除源文件
del "%BACK_FULL_NAME%.dmp"
echo "%BACK_FULL_NAME%exp.log"
echo 压缩并删除原有dmp文件结束! >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
echo 开始移动文件...... >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
rem 使用7ZIP压缩,注释掉WINRAR命令部分
rem move %BACKUP_DIR%\*.rar %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC\
move %BACKUP_DIR%\*.zip %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC\
echo 移动文件完成! >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
REM net send %userdomain% "数据库逻辑备份已于:%DATE% %time% 完成!"
echo .
echo 备份完成!!! >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
echo ===============备份数据库服务数据完成!!!============== >>%BACK_FULL_NAME%_bat.log
move %BACKUP_DIR%\*.log %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC\
echo .

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-257424-1-1.html 上篇帖子: MySQL价格提升了,JVM要收费了,ORACLE想干嘛了 下篇帖子: Oracle数据库表空间级的异地不完全恢复
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表