找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 108|回复: 11

发个WINDOWS下用Email附件备份数据VBS脚本

[复制链接]

12

主题

217

回帖

488

积分

中级会员

积分
488
发表于 2010-10-6 19:42:50 | 显示全部楼层 |阅读模式
前几天有个哥们Windows下的MYSQL数据库被未知生物袭击了
清空了所有的内容 然后删除了所有的库
用数据恢复软件恢复出来的 都是空表
那哥们可是欲哭无泪啊...

然后就让我帮忙搞个备份功能....
记得论坛里发过一个Linux下用邮箱附件备份数据的软件 就想照这功能写个Win下的
本人不才 没学过VBScript 不当之处 欢迎指出
是先先rar打包 再发送
压缩包里的rar.exe 可以在您的WinRAR根目录里找到.. 当前貌似3.93版[ol]
  • '-----------------------------------------------------------------------------------
  • '应用程序配置项↓
  • '-----------------------------------------------------------------------------------
  • '数据库目录 (目录均以"" 结尾)
  • Const MySqlDataDir = "C:\Users\Neta\Desktop\Data"
  • '备份数据库目录
  • Const MySqlBackupDir = "C:\Users\Neta\Desktop"
  • 'RAR压缩程序文件路径
  • Const RarExePath = "rar.exe"
  • '发件邮箱
  • Const EmailFrom = "send@qq.com"
  • '收件邮箱 推荐网易邮箱
  • Const EmailTo = "receive@163.com"
  • 'SMTP地址
  • Const SmtpServer = "smtp.qq.com"
  • 'SMTP端口
  • Const SmtpServerPort = 25
  • 'SMTP发信登陆帐号
  • Const SendUserName = "send@qq.com"
  • 'SMTP发信登陆密码
  • Const SendPassWord = "password"
  • '发送完毕是否删除备份数据文件 true | false
  • Const DeleteFile = true
  • '单个附件大小 单位为MB
  • Const AttachmentSize = 30
  • '---------------------------------------------------------------------------------------
  • '其他说明: 当执行RAR压缩的时候 会出现一个命令行窗口 显示压缩过程 请勿关闭!
  • '---------------------------------------------------------------------------------------
  • backupDateTime = now()
  • backupFileName = GetName(backupDateTime)
  • attach = MySqlBackupDir & backupFileName & ".rar"
  • '开始备份
  • Set WshShell = CreateObject("WScript.Shell")
  • Set fso = CreateObject("Scripting.FileSystemObject")
  • WshShell.run RarExePath & " a -ibck " & attach & " " & MySqlDataDir,,true
  • Set backupFile = fso.GetFile(attach)
  • '判断附件大小 如果超过AttachmentSize  则进行分卷打包
  • IF backupFile.Size > AttachmentSize * 1024 * 1024 Then
  •   '计算分卷打包文件个数
  •   TotalFile = GetInteger(backupFile.Size / (AttachmentSize * 1024 * 1024))
  •   
  •   '重新取得文件打包时间
  •   backupDateTime = now()
  •   backupFileName = GetName(backupDateTime)
  •   
  •   '开始分卷打包
  •   WshShell.run RarExePath & " a -v" & AttachmentSize & "m -ibck " & MySqlBackupDir & backupFileName & " " & attach,,true
  •   
  •   '删除初次打包的文件
  •   Call DelFile(attach)
  •   
  •   '发送分卷
  •   For P = 1 To TotalFile
  •     attach = MySqlBackupDir & backupFileName & ".part" & P & ".rar"
  •     Call SendMail(attach,backupDateTime)
  •   Next
  •   
  • Else
  •   Call SendMail(attach,backupDateTime)
  • End IF
  • Set WshShell = Nothing
  • Set fso = Nothing
  • Function GetName(time)
  •         GetName = Replace(Replace(Replace(time, "/", "-"), " ", "-"), ":", "-")
  • End Function
  • Function GetInteger(number)
  •         GetInteger = int(number)
  •         IF GetInteger 复制代码
    [ 本帖最后由 Neta 于 2010-10-6 19:44 编辑 ]
  • 回复

    使用道具 举报

    274

    主题

    4374

    回帖

    9622

    积分

    论坛元老

    积分
    9622
    发表于 2010-10-6 19:44:14 | 显示全部楼层
    不错。。。
    回复

    使用道具 举报

    12

    主题

    217

    回帖

    488

    积分

    中级会员

    积分
    488
     楼主| 发表于 2010-10-6 19:45:46 | 显示全部楼层


      usa 真是极速 我还没编辑完沙发就没了...
    回复

    使用道具 举报

    147

    主题

    2095

    回帖

    4687

    积分

    论坛元老

    积分
    4687
    发表于 2010-10-6 19:47:55 | 显示全部楼层
    好帖还是要支持支持
    回复

    使用道具 举报

    3

    主题

    318

    回帖

    675

    积分

    高级会员

    积分
    675
    发表于 2010-10-6 19:53:17 | 显示全部楼层
    支持一下
    回复

    使用道具 举报

    78

    主题

    307

    回帖

    886

    积分

    高级会员

    积分
    886
    发表于 2010-10-6 20:37:12 | 显示全部楼层
    支持一下!
    回复

    使用道具 举报

    0

    主题

    62

    回帖

    132

    积分

    注册会员

    积分
    132
    发表于 2010-10-6 20:39:55 | 显示全部楼层
    不错。收藏一个!
    回复

    使用道具 举报

    137

    主题

    9302

    回帖

    1万

    积分

    论坛元老

    积分
    19063
    发表于 2010-10-6 20:51:06 | 显示全部楼层
    好贴,要给分。
    回复

    使用道具 举报

    194

    主题

    3768

    回帖

    8174

    积分

    论坛元老

    积分
    8174
    发表于 2010-10-7 16:13:21 | 显示全部楼层
    WScript.Shell
    必须开着,有一定安全风险
    回复

    使用道具 举报

    12

    主题

    217

    回帖

    488

    积分

    中级会员

    积分
    488
     楼主| 发表于 2010-10-7 16:13:54 | 显示全部楼层
    支持好东西收藏了

    不过在win下如果bat能解决的我更喜欢用bat
    嘿嘿
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    Archiver|手机版|小黑屋|Discuz! X

    GMT+8, 2025-1-11 15:52 , Processed in 0.024769 second(s), 5 queries , Gzip On, Redis On.

    Powered by Discuz! X3.5

    © 2001-2024 Discuz! Team.

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