数据库定时备份

项目开发完毕正常运行以后,需要数据库定时备份,以备不时之需,需求有几点
1.系统有windows server 和 linux centOS
2.数据库有mysql和oracle
3.数据库密码不要暴露
4.备份后的数据库文件不要暴露
5.可按天或者小时进行备份,能自动删除时间>的备份文件

1 备份的两种方案

1.1数据库客户端实现的备份

数据库客户端主要是用的navicat

  1. 新建navicat计划(定时任务);
  2. 将数据库备份任务放入计划;
  3. 需要时可在navicat备份工具中恢复
    ps:备份后的数据是psc格式的,mysql、oracle都可以使用;
    经过考虑没采用这个方案,原因如下:
  • 需要navicat,并不是所有地方有合适有navicat的;
  • 不能实现密码加密,不能实现密码加密,

1.2 命令行实现数据加密

mysql有mysqldump命令,可备份出.sql格式的文件;
oracle有exp命令,可导出.dmp格式的文件,可以实现数据备份;
windows,linux均有计划任务选项可以把备份任务添加到计划里,实现定时备份,我们具体研究这一种;

2 linux + oracle

3 windows服务器下oracle定时备份

三个步骤
通过oracle的exp命令导出.dmp文件
编写dbBak.bat,
将dbBak.bat敏感信息隐藏
将dbBak.bat加入计划任务

通过oracle的exp命令导出.dmp文件

exp dbUserName/dbUserPassword@orcl file= D:/test/db_bak.dmp log=D:/test/db_bak/.log

其中dbUserName/dbUserPassword为数据库的账号密码,file= D:/test/db_bak.dmp,指定dmp文件路径,log=D:/test/db_bak/.log指定日志的路径,
如果不想导出全部表,还可以通过table参数指定需要导出的表;
打开cmd测试
控制台出现Export terminated successfully without warnings.
指定路径出现指定文件即可
通过后即可

编写dbBak.bat

这个我们主要实现备份文件名规则,定时删除过期文件

echo 初始化时间日期字符串,作为文件名
set THISDATE=%DATE:~0,4%%DATE:~5,2%%DATE:~8,2%
set THISDATE=%THISDATE: =0%
set THISTIME=%TIME:~0,2%%TIME:~3,2%  
set THISTIME=%THISTIME: =0%

exp userName/password@orcl file= D:/Java/db_bak_lyb2/lyb2_%THISDATE%_%THISTIME%.dmp log=D:/Java/db_bak_lyb2/lyb2_%THISDATE%_%THISTIME%.log 
echo 删除15天前的记录
forfiles /p D:\Java\db_bak_lyb2\ /m lyb2_*.* /d -15 /c "cmd /c del @path\"

将dbBak.bat敏感信息隐藏

隐藏可以有两个方案,将dbBak.bat中的内容通过密钥加密,执行时在解密;
另一个简单点就是直接打包成exe,我们就直接打包了
下载bat2exe,可以将bat转换为exe
下载地址
双击运行后,先选择bat所在文件夹(文件夹中可以有.ico文件,作为生成exe的图标),再选择exe输出的文件夹,即可

将dbBak.exe加入计划任务

依次打开
计算机管理>系统工具>任务计划程序>任务计划程序库>Microsoft>windows
然后点击创建基本任务,如图(win server 12)

在这里插入图片描述
然后基本就是傻瓜式操作了,选择自己合适的时间间隔执行,就可以啦

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、提供了oracle数据库备份脚本,导出dmp文件 2、定时任务由操作系统提供的支持,在操作系统中设置定时任务,由操作系统定期执行脚本 3、补充。压缩包脚本有点问题,不能删除旧的备份文件。需要自动删除历史备份文件请用最新脚本: @echo off @echo ================================================ @echo windows环境下Oracle数据库的自动备份脚本 @echo 说明:启动备份时,需要配置以下变量 @echo 1、BACKUP_DIR 指定要备份到哪个目录 @echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名 @echo 3、ORACLE_PASSWORD 指定备份所用的Oracle密码 @echo 4、ORACLE_DB 指定备份所用的Oracle连接名 @echo 5、BACK_OPTION 备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 等等.... @echo 6、RAR_CMD 指定RAR命令行压缩工具所在目录 @echo ================================================ rem 以下变量需要根据实际情况配置 set BACKUP_DIR=D:\tools\oracle_bak\backup230 set ORACLE_USERNAME=PLATADMIN set ORACLE_PASSWORD=123456 set ORACLE_DB=ORCL set BACK_OPTION=owner=PLATADMIN set RAR_CMD="D:/Program Files/WinRAR/Rar.exe" rem for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a rem set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_ set BACK_NAME=%Date:~0,4%%Date:~5,2%%Date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2% set BACK_FULL_NAME=%BACKUP_DIR%/%BACK_NAME% rem 开始备份 exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%exp.log" rem 压缩并删除原有文件 %RAR_CMD% a -df "%BACK_FULL_NAME%back.rar" "%BACK_FULL_NAME%.dmp" "%BACK_FULL_NAME%exp.log" rem 删除15天前的备份文件 forfiles /p %BACKUP_DIR% /s /m *.rar /d -15 /c "cmd /c del @file"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值