java实现的MySQL自动备份和还原(struts2+Hibernate)---兼容 window+Linux
时间:2022-03-10 17:06
相信很多朋友都经历过数据库出问题的情况,我也同样(见我的上一篇博文: )。如果数据很大或者很重要,那么恢复起来是相当困难的,所以我们在做一个相对完善的系统时,数据库的备份/还原功能是必不可少的。本文将在javaEE环境下实现MySQL的自动备份/还原,使用了struts2和hibernate框架,MySQL版本是5.1.16。
下图展示的是web application的执行流程,
(使用时,请将这些配置修改为本机的实际值,当OS为Linux是,mysqlpath可以不用设置,前提是 mysqldump 命令有效)
下面是MySQLBackupWorker中在window环境下的备份实现(默认的编码是utf-8,可以改为本机值):
1publicvoid backup(boolean isRe) throws Exception { 2boolean isWindow = isWindowsOS(); 3 isRestore = isRe; 4if(isWindow){ 5this.backupWindow(); 6 }else{ 7this.backupLinux(); 8 } 9}1011/**12 * window下的mysql备份13 * @method name: backupWindow14 * @return type: void15*/16privatevoid backupWindow(){17try {18 String sqlPath = bkPath + getBackupName();19 mkDir(sqlPath);2021 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);4041 System.out.println(sb.toString());42 Runtime cmd = Runtime.getRuntime();43try {44 Process p = cmd.exec(sb.toString());45int tag = p.waitFor();46 System.out.println("result::: "+tag);47if(tag == 0)48 done = true;49 } catch (IOException e) {50 e.printStackTrace();51 }52 } catch (Exception e) {53 e.printStackTrace();54 }55 }
获取更多源代码:
【本文为小弟原创文章,引用请注明出处,谢谢】
--------------------------------
文章首发:http://www.cnblogs.com/nerve/p/3715487.html
--------------------------------
本文出自 “” 博客,请务必保留此出处
java实现的MySQL自动备份和还原(struts2+Hibernate)---兼容 window+Linux,布布扣,bubuko.com