win系统下备份逻辑oracle及上传ftp脚本

@echo off
@echo =========================================================================
@echo Oracle 11g 数据库的自动导出备份脚本(windows环境)。
@echo 说明:启动备份时,需要配置以下变量
@echo 1、BACKUP_DIR 指定要备份到哪个中间目录,压缩完成后将被移动到BACKUP_WAREHOUSE目录下
@echo 3、ORACLE_USERNAME 指定备份所用的Oracle用户名
@echo 4、ORACLE_PASSWORD 指定备份所用的Oracle密码
@echo 5、ORACLE_DB 指定备份所用的Oracle服务名
@echo 7、RAR_CMD 指定RAR命令行压缩工具所在目录
@echo =========================================================
set BACKUP_DIR=D:\zjwmsbak\dump
set ORACLE_USERNAME= user    用户
set ORACLE_PASSWORD= password    密码
set ORACLE_DB= SID    (连接符,一般用实例名)
set RAR_CMD="C:\Program Files (x86)\WinRAR\WinRAR.exe"(压缩软件目录)
@for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a
for /f "tokens=1,2,3" %%a in ('echo %date:~-1%') do set WEEK=%%a
if %WEEK%==一 (set WEEK=1)
if %WEEK%==二 (set WEEK=2)
if %WEEK%==三 (set WEEK=3)
if %WEEK%==四 (set WEEK=4)
if %WEEK%==五 (set WEEK=5)
if %WEEK%==六 (set WEEK=6)
if %WEEK%==日 (set WEEK=7)
echo,
set BACK_NAME=%ORACLE_DB%_%ORACLE_USERNAME%_WEEK%WEEK%
set BACK_FULL_NAME=%BACKUP_DIR%\%BACK_NAME%        (设置有日期格式的文件名,方便轮询覆盖,节约存储资源)
REM 将操作记入批处理日志 %BACKUP_DIR%\%BACK_NAME%_bat.log
echo ==================备份103服务器 ITCQB帐号下的数据================= >>%BACKUP_DIR%\%BACK_NAME%_bat.log
echo 备份开始...... >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACKUP_DIR%\%BACK_NAME%_bat.log
D:\app\Administrator\product\11.2.0\dbhome_1\BIN\expdp %ORACLE_USERNAME%/%ORACLE_PASSWORD% file="%BACK_NAME%.dmp" full=y content=ALL log="%BACK_NAME%_exp.log" DIRECTORY=dump_bak compression=ALL
%RAR_CMD% a -df "%BACKUP_DIR%\%BACK_NAME%_logic.rar" "%BACKUP_DIR%\%BACK_NAME%.dmp"
echo 压缩并删除原有dmp文件结束! >>%BACKUP_DIR%\%BACK_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACKUP_DIR%\%BACK_NAME%_bat.log
echo 开始移动文件...... >>%BACKUP_DIR%\%BACK_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACKUP_DIR%\%BACK_NAME%_bat.log
REM net send %userdomain% "数据库逻辑备份已于:%DATE% %time% 完成!"
echo .
@Echo Off
Echo open $ftp_IP>%BACKUP_DIR%\ftp.up
Echo $ftp_user>>%BACKUP_DIR%\ftp.up
Echo $ftp_password>>%BACKUP_DIR%\ftp.up
Echo Cd .\ >>%BACKUP_DIR%\ftp.up
Echo bin>>%BACKUP_DIR%\ftp.up
Echo put "%BACKUP_DIR%\%BACK_NAME%_logic.rar">>%BACKUP_DIR%\ftp.up
Echo bye>>%BACKUP_DIR%\ftp.up
FTP -s:%BACKUP_DIR%\ftp.up



猜你喜欢

转载自blog.csdn.net/tab_007/article/details/80730075