相信很多朋友都经历过数据库出问题的情况,我也同样(见我的上一篇博文:phpmyadmin误删表后的恢复过程(心惊胆跳啊)   )。如果数据很大或者很重要,那么恢复起来是相当困难的,所以我们在做一个相对完善的系统时,数据库的备份/还原功能是必不可少的。本文将在javaEE环境下实现MySQL的自动备份/还原,使用了struts2和hibernate框架,MySQL版本是5.1.16。

  下图展示的是web application的执行流程,

  

  Timer是在一个随着application启动而启动的servlet中初始化,并接受一个名叫‘BACKUP_DEPLY'的参数,它告诉Timer多久去备份一次数据库(单位为小时):

  

  1. <servlet>
  2. <servlet-name>StartupServlet</servlet-name>
  3. <servlet-class>com.nerve.web.servlet.StartupServlet</servlet-class>
  4.  
  5. <load-on-startup>1</load-on-startup>
  6.  
  7. <init-param>
  8. <param-name>BACKUP_DELAY</param-name>
  9. <param-value>24</param-value><!--自动备份程序执行间隔,单位为小时-->
  10. </init-param>
  11. </servlet>

  每次备份数据库后,会将备份信息保存到数据库中,为此我们定义了一个PO,如下:

  1. public class Backup{
  2. private int id;
  3. private String name;
  4. private long size;
  5. private Date addDate;
  6.  
  7. //setter and getter
  8. }

  

  

  

  上图是备份过程中主要用到的类,大概过程为:

  1.当Timer开始执行备份操作时,会调用BackupService(BackupServiceImpl为其实现类)中的backup()方法

  2.BackupService会实例化一个BackWorker(MySQLBackupWorker为其实现类),并调用它的backup(boolean isRestore)throws Excetion方法来完成备份

  3.当BackupWorker的isDone()方法返回true时,则表示备份成功(这时可以通过BackupWorker的getFileName()方法获取保存的文件名),否则是失败

  

  BackupWorker接口定义如下:

  1. public interface BackupWorker {
  2.  
  3. public void backup(boolean isRestore) throws Exception;
  4.  
  5. public void reload(String path) throws Exception;
  6.  
  7. /**
  8. * 是否备份成功
  9. * @method name: isDone
  10. * @return type: boolean
  11. * @return
  12. */
  13. public boolean isDone();
  14.  
  15. /**
  16. * 获取备份后文件的名称(不包括目录)
  17. * @method name: getFileName
  18. * @return type: String
  19. * @return
  20. */
  21. public String getFileName();
  22.  
  23. /**
  24. * 获取备份后文件的大小
  25. * @method name: getFileSize
  26. * @return type: long
  27. * @return
  28. */
  29. public long getFileSize();
  30.  
  31. /**
  32. * 获取配置文件中自动备份的时间间隔,单位为小时
  33. * @method name: getHours
  34. * @return type: int
  35. * @return
  36. */
  37. public int getHours();
  38.  
  39. /**
  40. * 更新自动备份的时间间隔
  41. * @method name: setHours
  42. * @return type: void
  43. * @param hours
  44. */
  45. public void setHours(int hours);
  46.  
  47. /**
  48. * 删除备份文件
  49. * @method name: delete
  50. * @return type: void
  51. * @param fileName
  52. */
  53. public void delete(String fileName);
  54. }

  MySQLBackupWorker是MySQL的备份/还原类,实现了BackupWorker接口,在构造函数被执行时,会读取我们预设的MySQL相关设置(即上面类图中的MySQLBackup.properties),配置文件中包含如下内容:

(使用时,请将这些配置修改为本机的实际值,当OS为Linux是,mysqlpath可以不用设置,前提是 mysqldump 命令有效)

下面是MySQLBackupWorker中在window环境下的备份实现(默认的编码是utf-8,可以改为本机值):

  1. public void backup(boolean isRe) throws Exception {
  2. boolean isWindow = isWindowsOS();
  3. isRestore = isRe;
  4. if(isWindow){
  5. this.backupWindow();
  6. }else{
  7. this.backupLinux();
  8. }
  9. }
  10.  
  11. /**
  12. * window下的mysql备份
  13. * @method name: backupWindow
  14. * @return type: void
  15. */
  16. private void backupWindow(){
  17. try {
  18. String sqlPath = bkPath + getBackupName();
  19. mkDir(sqlPath);
  20.  
  21. StringBuffer sb = new StringBuffer();
  22. sb.append(mysqlPath);
  23. sb.append("mysqldump ");
  24. sb.append("--opt ");
  25. sb.append("-h ");
  26. sb.append(host);
  27. sb.append(" ");
  28. sb.append("--user=");
  29. sb.append(loginName);
  30. sb.append(" ");
  31. sb.append("--password=");
  32. sb.append(loginPass);
  33. sb.append(" ");
  34. sb.append("--lock-all-tables=true ");
  35. sb.append("--result-file=");
  36. sb.append(sqlPath);
  37. sb.append(" ");
  38. sb.append("--default-character-set=utf8 ");
  39. sb.append(dbName);
  40.  
  41. System.out.println(sb.toString());
  42. Runtime cmd = Runtime.getRuntime();
  43. try {
  44. Process p = cmd.exec(sb.toString());
  45. int tag = p.waitFor();
  46. System.out.println("result::: "+tag);
  47. if(tag == 0)
  48. done = true;
  49. } catch (IOException e) {
  50. e.printStackTrace();
  51. }
  52. } catch (Exception e) {
  53. e.printStackTrace();
  54. }
  55. }

获取更多源代码:源代码

【本文为小弟原创文章,引用请注明出处,谢谢】

java实现的MySQL自动备份和还原(struts2+Hibernate)---兼容 window+Linux的更多相关文章

  1. Mysql自动备份与还原 转

    Mysql自动备份与还原 一.自动备份:将以下代码保存为*.bat批处理脚本,然后再添加Windows定时作业,如每天凌晨2点执行:set s=%date:~0,4%%date:~5,2%%date: ...

  2. Java Web 实现Mysql 数据库备份与还原

    前段时间某某删库事故付出的惨重代价告诉我们: 数据备份的必要性是企业数据管理极其重要的一项工作. 1. Mysql备份与还原命令 备份命令: mysqldump -h127.0.0.1 -uroot ...

  3. MySQL的备份和还原

    MySQL的备份和还原 备份:副本    RAID1,RAID10:保证硬件损坏而不会业务中止:        DROP TABLE mydb.tb1; 备份类型:        热备份.温备份和冷备 ...

  4. MySQL的备份与还原以及常用数据库查看命令

    MySQL命令行导出数据库: 1,进入MySQL目录下的bin文件夹:cd MySQL中到bin文件夹的目录 如我输入的命令行:cd C:\Program Files\MySQL\MySQL Serv ...

  5. mysql数据库备份与还原(转)

    MySQL备份和还原,都是利用mysqldump.mysql和source命令来完成的. 1.Linux下MySQL的备份与还原 1.1 备份 [root@localhost ~]# cd /var/ ...

  6. MySQL学习——备份和还原

    MySQL学习——备份和还原 摘要:本文主要学习了如何备份和还原数据库. 部分内容来自以下博客: https://www.cnblogs.com/chenmh/p/5300370.html 常用命令 ...

  7. mysql数据库-备份与还原实操

    目录 备份工具 1 基于 LVM 的快照备份(几乎热备) 2 数据库冷备份和还原 3 mysqldump备份工具 3.1 实战备份策略 3.1.1 全备份 3.1.2 分库分表备份 3.2 mysql ...

  8. mysql 自动备份和nginx自动安装脚本

    一.自动备份Mysql脚本: 如下脚本为mysql自动备份脚本,仅供参考,可以根据实际情况修改. #!/bin/sh #auto backup mysql #wugk #Define PATH定义变量 ...

  9. 转 MySQL 数据备份与还原

    MySQL 数据备份与还原 原贴:http://www.cnblogs.com/kissdodog/p/4174421.html   一.数据备份 1.使用mysqldump命令备份 mysqldum ...

随机推荐

  1. [SQL]replace替换字符串中的字符

    ','**') --下面是结果集 /* ----------- 12345678** */ SELECT replace(CONVERT(varchar(),GETDATE(),),'-','') - ...

  2. C++primer 练习10.16

    // 10.3.2.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include<iostream> #include< ...

  3. .NET类型转换的常用方式

    第一.隐式转换 byte, short, int, long, fload, double 等,根据这个排列顺序,各种类型的值依次可以向后自动进行转换 如果需要逆转换,则需要进行强制转化.同时考虑溢出 ...

  4. 在SoCEDS环境下编译和更新preloader和uboot程序的方法

    在SoCEDS环境下编译和更新preloader和uboot程序的方法   前面有介绍preloader在HPS boot过程中的的作用,接下来讲述下用户在SoCEDS环境下改如何编译preloade ...

  5. 502 Bad Gateway什么意思

    http://baike.baidu.com/link?url=U2ijg5T5PG_tTkY67mqfx07co7qGqvMB32rbLwq4S2ThBSRIWWvU76Y0Mb8Z3z6nbViN ...

  6. 转载KMP

    出处: http://www.ruanyifeng.com/blog/2013/05/Knuth%E2%80%93Morris%E2%80%93Pratt_algorithm.html 在假期之前,断 ...

  7. 如何设置修改WPS批注上的用户信息名称

    http://jingyan.baidu.com/article/6b18230953cec7ba59e1596b.html 点击左上角的“WPS文字”:   选择“选项”:   点击“用户信息”: ...

  8. Beginning SDL 2.0(1) SDL功能简介

    原文链接为 http://wiki.libsdl.org/Introduction. 由于近期整理音视频可视化的技术,发现好久不更新的SDL发布了2.0版本,以前也没有过于关注,这里准备尝试下.了解S ...

  9. centos 6.5 samba简单配置

    1.安装samba yum -y install samba  (我的显示已经安装啦!) 2.编辑samba的配置文件 vi /etc/samba/smb.conf 用 testparm查看我配置后的 ...

  10. 学习记录 java泛型资料

    java泛型资料: 1. 概述在引入范型之前,Java类型分为原始类型.复杂类型,其中复杂类型分为数组和类.引入范型后,一个复杂类型就可以在细分成更多的类型.例如原先的类型List,现在在细分成Lis ...