java 实现mysql数据库备份
package com.itenp.gen.action;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.annotation.Resource;
import org.apache.log4j.Logger;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Controller;
import com.itenp.gen.common.Constants;
import com.itenp.gen.common.ParameterUtil;
import com.itenp.gen.service.i.BackUpServiceI;
import com.itenp.gen.system.PropertiesCache;
import com.itenp.gen.vo.BackUpVO;
import com.itenp.gen.vo.UserVO;
@SuppressWarnings("serial")
@Scope("prototype")
@Controller("backupAction")
public class BackUpAction extends BaseAction {
private static Logger log = Logger.getLogger(BackUpAction.class);
private String databaseDirectory = PropertiesCache.getInstance().getDatabaseDirectory(); //数据库bin路径
private String databaseName = PropertiesCache.getInstance().getDatabaseName();//数据库名
private String userName = PropertiesCache.getInstance().getUserName();
private String userPwd = PropertiesCache.getInstance().getUserPwd();
private String copyDbCmd = PropertiesCache.getInstance().getCopyDbCmd();//数据库备份命令
private String copyprocCmd = PropertiesCache.getInstance().getCopyprocCmd();//存储工程备份命令
private String copyedFilePath = PropertiesCache.getInstance().getCopyedFilePath(); //备份后的文件存放位置
private String restoreCmd = PropertiesCache.getInstance().getRestoreCmd(); //数据库还原命令
private String msg = "";
private String msg1 = "";
private BackUpServiceI service;
@Resource(name="backupService")
public void setBackupService(BackUpServiceI service){
this.service=service;
}
@SuppressWarnings("unchecked")
public String list() throws Exception
{
//System.out.println("copyedFilePath"+copyedFilePath);
HashMap map = new HashMap();
//得到符合条件的记录List
List<BackUpVO> list = (List)service.findList(map);
request.setAttribute("list", list);
log.debug("####"+PropertiesCache.getInstance().getTemplateDirectory());
// System.out.println(PropertiesCache.getInstance().getTemplateDirectory());
return "success";
}
@SuppressWarnings("unchecked")
public String backup() throws Exception
{
Runtime rt = Runtime.getRuntime();
// 调用 mysql 的 cmd:
/*System.out.println("数据库bin路径"+databaseDirectory);
System.out.println("数据库名"+databaseName);
System.out.println("用户名"+userName);
System.out.println("密码"+userPwd);
System.out.println("数据库备份命令"+copyDbCmd);
System.out.println("存储工程备份命令"+copyprocCmd);*/
String str = databaseDirectory+"/"+copyDbCmd+" --no-defaults "+"-u"+userName+" "+"-p"+userPwd+" "+copyprocCmd+" "+"--set-charset=utf-8"+" "+databaseName;
//str = "D:\SOFT\MySQL\MySQL Server 5.5\bin/mysqldump -uroot -proot -R --set-charset=utf-8 nlnk";
//System.out.println(str);
// Process child = rt.exec(databaseDirectory+"/"+copyDbCmd+" "+"-u"+userName+" "+"-p"+userPwd+" "+copyprocCmd+" "+"--set-charset=utf-8"+" "+databaseName);// 设置导出编码为utf8。这里必须是utf8
Process child = rt.exec(str);// 设置导出编码为utf8。这里必须是utf8
//调用mysql的cmd:备份某个表
// Process childtable = rt
// .exec("D:/db/mysql/mysql-5.0.45-win32/bin/mysqldump -uroot -pmysql --set-charset=utf8 ibtts t_a_dbbak");// 设置导出编码为utf8。这里必须是utf8
// Process childtable = rt
// .exec(databaseDirectory+"/"+copyDbCmd+" "+"-u"+userName+" "+"-p"+userPwd+" "+"--set-charset=utf8"+" "+databaseName+" "+"t_a_dbbak");// 设置导出编码为utf8。这里必须是utf8
// 把进程执行中的控制台输出信息写入.sql文件,即生成了备份文件。注:如果不对控制台信息进行读出,则会导致进程堵塞无法运行
InputStream in = child.getInputStream();// 控制台的输出信息作为输入流
InputStreamReader xx = new InputStreamReader(in, "utf8");// 设置输出流编码为utf8。这里必须是utf8,否则从流中读入的是乱码
String inStr;
StringBuffer sb = new StringBuffer("");
String outStr;
// 组合控制台输出信息字符串
BufferedReader br = new BufferedReader(xx);
// System.out.println("------------"+br.readLine());
while ((inStr = br.readLine()) != null) {
sb.append(inStr + "\r\n");
}
outStr = sb.toString();
//判断是否保存成功
if(outStr != null && !outStr.trim().equals("")){
msg="ok";
}
//System.out.println("-----"+outStr);
//创建文件名称
SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmss");
String today=format.format(new Date());
//String targetDirectory = scontext.getRealPath("/WEB-INF/DBbackup");
// System.out.println(targetDirectory);
// 要用来做导入用的sql目标文件:D:/ibtts.sql
FileOutputStream fout = new FileOutputStream(
copyedFilePath+"/"+today+"ibtts.sql" );
OutputStreamWriter writer = new OutputStreamWriter(fout, "utf8");
writer.write(outStr);
// 注:这里如果用缓冲方式写入文件的话,会导致中文乱码,用flush()方法则可以避免
writer.flush();
// 别忘记关闭输入输出流
in.close();
xx.close();
br.close();
writer.close();
fout.close();
// System.out.println("/* Output OK! */");
//数据添加到数据库
HashMap map = new HashMap();
map.put("db_nm", "ibtts");
map.put("bk_nm", today+"ibtts.sql");
map.put("bk_user",((UserVO)session.get(Constants.S_LOGIN_USER)).getUser_id());
service.create(map);
// copytable();
return list();
}
/**
* 数据的恢复
*/
@SuppressWarnings("unchecked")
public String load() throws Exception
{
copytable();
//得到页面所有参数
Map<String, String> map = ParameterUtil.getStringMap(request,session);
//String targetDirectory = scontext.getRealPath("/WEB-INF/DBbackup");
//获取id后进行查询
BackUpVO vo=(BackUpVO) service.findById(map);
String fPath=copyedFilePath+"/"+vo.getBk_nm();
System.out.println(fPath);
//map.put("Id", vo.getId());
//String fPath = "D:/ibtts.sql";Runtime rt = Runtime.getRuntime();
// 调用 mysql 的 cmd:
//Process child = rt.exec("D:/db/mysql/mysql-5.0.45-win32/bin/mysql -uroot -pmysql ibtts");
Process child = rt.exec(databaseDirectory+"/"+restoreCmd+" "+"-u"+userName+" "+"-p"+userPwd+" "+databaseName);
//System.out.println(databaseDirectory+"/"+restoreCmd+" "+"-u"+userName+" "+"-p"+userPwd+" "+databaseName);
java.io.OutputStream out =child.getOutputStream();//控制台的输入信息作为输出流
String inStr;
StringBuffer sb = new StringBuffer("");
String outStr;
BufferedReader br = new BufferedReader(new InputStreamReader(
new FileInputStream(fPath), "utf8"));
while ((inStr = br.readLine()) != null) {
sb.append(inStr + "\r\n");
}
outStr = sb.toString();
OutputStreamWriter writer = new OutputStreamWriter(out, "utf8");
writer.write(outStr);
// 注:这里如果用缓冲方式写入文件的话,会导致中文乱码,用flush()方法则可以避免
writer.flush();
// 别忘记关闭输入输出流
out.close();
br.close();
writer.close();
//获取还原用户
map.put("restore_user", ((UserVO)session.get(Constants.S_LOGIN_USER)).getUser_id());
//service.modify(map);
restoretable(map); //---------------
//System.out.println(map);
//System.out.println("恢复成功");
request.getSession().setAttribute("dbmap", map);
msg1 = "tiaozhuan";
return "success";
}
//对特定表的处理
public void copytable() throws Exception
{
Runtime rt = Runtime.getRuntime();
// 调用 mysql 的 cmd:
//调用mysql的cmd:备份某个表
//Process child = rt
// .exec("D:/db/mysql/mysql-5.0.45-win32/bin/mysqldump -uroot -pmysql --set-charset=utf8 ibtts t_a_dbbak");// 设置导出编码为utf8。这里必须是utf8
Process child = rt.exec(databaseDirectory+"/"+copyDbCmd+" --no-defaults "+"-u"+userName+" "+"-p"+userPwd+" "+"--set-charset=utf8"+" "+databaseName+" "+"t_a_dbbak");// 设置导出编码为utf8。这里必须是utf8
// 把进程执行中的控制台输出信息写入.sql文件,即生成了备份文件。注:如果不对控制台信息进行读出,则会导致进程堵塞无法运行
InputStream in = child.getInputStream();// 控制台的输出信息作为输入流
// System.out.println(databaseDirectory+"/"+copyDbCmd+" --no-defaults "+"-u"+userName+" "+"-p"+userPwd+" "+"--set-charset=utf8"+" "+databaseName+" "+"t_a_dbbak");
InputStreamReader xx = new InputStreamReader(in, "utf8");// 设置输出流编码为utf8。这里必须是utf8,否则从流中读入的是乱码
String inStr;
StringBuffer sb = new StringBuffer("");
String outStr;
// 组合控制台输出信息字符串
BufferedReader br = new BufferedReader(xx);
while ((inStr = br.readLine()) != null) {
sb.append(inStr + "\r\n");
}
outStr = sb.toString();
//String targetDirectory = scontext.getRealPath("/WEB-INF/DBbackup");
// 要用来做导入用的sql目标文件:D:/ibtts.sql
FileOutputStream fout = new FileOutputStream(
copyedFilePath+"/"+"ibtts_talbe.sql" );
OutputStreamWriter writer = new OutputStreamWriter(fout, "utf8");
writer.write(outStr);
// 注:这里如果用缓冲方式写入文件的话,会导致中文乱码,用flush()方法则可以避免
writer.flush();
// 别忘记关闭输入输出流
in.close();
xx.close();
br.close();
writer.close();
fout.close();
}
public void restoretable(Map map) throws Exception
{
String fPath=copyedFilePath+"/"+"ibtts_talbe.sql";
//String fPath = "D:/ibtts.sql";Runtime rt = Runtime.getRuntime();
// 调用 mysql 的 cmd:
//Process child = rt.exec("D:/db/mysql/mysql-5.0.45-win32/bin/mysql -uroot -pmysql ibtts");
Process child = rt.exec(databaseDirectory+"/"+restoreCmd+" "+"-u"+userName+" "+"-p"+userPwd+" "+databaseName);
System.out.println(databaseDirectory+"/"+restoreCmd+" "+"-u"+userName+" "+"-p"+userPwd+" "+databaseName);
java.io.OutputStream out =child.getOutputStream();//控制台的输入信息作为输出流
String inStr;
StringBuffer sb = new StringBuffer("");
String outStr;
BufferedReader br = new BufferedReader(new InputStreamReader(
new FileInputStream(fPath), "utf8"));
while ((inStr = br.readLine()) != null) {
sb.append(inStr + "\r\n");
}
outStr = sb.toString();
OutputStreamWriter writer = new OutputStreamWriter(out, "utf8");
writer.write(outStr);
// 注:这里如果用缓冲方式写入文件的话,会导致中文乱码,用flush()方法则可以避免
writer.flush();
// 别忘记关闭输入输出流
out.close();
br.close();
writer.close();
//System.out.println(map);
/*int sign=0;
BackUpVO vo=null;
while(vo==null){
vo=(BackUpVO) service.findById(map);
if(vo!=null||sign==100){
break;
}
sign++;
}
service.modify(map);*/
}
@SuppressWarnings("unchecked")
public String upbak() throws Exception{
HashMap map = new HashMap();
map = (HashMap)request.getSession().getAttribute("dbmap");
int sign=0;
BackUpVO vo=null;
while(vo==null){
vo=(BackUpVO) service.findById(map);
if(vo!=null||sign==100){
break;
}
sign++;
}
service.modify(map);
return list();
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
}
public String getMsg1() {
return msg1;
}
public void setMsg1(String msg1) {
this.msg1 = msg1;
}
}
- 本文来自:Linux教程网
java 实现mysql数据库备份的更多相关文章
- Java实现MySQL数据库备份(二)
权声明:本文为博主原创文章,未经博主允许不得转载. 博客<Java实现MySQL数据库备份(一)>使用I/O流的方式实现了MySQL数据库的备份,这种方法比较繁杂,下面介绍另一种备份MyS ...
- Java实现mysql数据库备份
Runtime是一个与JVM运行时环境有关的类,这个类是Singleton的. Runtime.getRuntime()可以取得当前JVM的运行时环境,这也是在Java中唯一一个得到运行时环境的方法. ...
- Java达到MySQL数据库备份(两)
博客<Java实现MySQL数据库备份(一)>使用I/O流的方式实现了MySQL数据库的备份,这样的方法比較繁杂.以下介绍还有一种备份MySQL数据库的方法: import java.io ...
- Java实现MySQL数据库备份(一)
下班了,利用闲暇时间总结一下如何使用Java语言实现MySQL数据库备份: import java.io.BufferedReader; import java.io.File; import jav ...
- JSP 实现 之 调用java方法实现MySQL数据库备份和恢复
package cn.qm.db; import java.io.BufferedReader; import java.io.DataInputStream; import java.io.IOEx ...
- Java连接mysql数据库攻略
一. 软件下载 Mysql 下载版本:4.1.11 http://dev.mysql.com/downloads/mysql/4.1.html JDBC驱动 下载版本:3.1.8 http://dev ...
- Xtrabackup原理及使用innobackupex进行MySQL数据库备份恢复
Xtrabackup是由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具. Xtrabackup中主要包含两个工 ...
- TODO:MongoDB MySQL数据库备份
TODO:MongoDB MySQL数据库备份 1. MongoDB使用命令备份 mongodump进行整个数据库备份,主要用到的命令参数: -d 要备份的数据库 -o 输出的路径 ./mongodu ...
- Java实现MySQL数据库导入
距离上班还有一段时间.现在总结一下如何使用Java语言实现MySQL数据库导入: 首先新建名为test的数据库: 其次执行下面Java代码: import java.io.File; import j ...
随机推荐
- 抛弃Https让Cas以Http协议提供单点登录服务
本文环境: 1.apache-tomcat-7.0.50-windows-x86 2.cas-server-3.4.11 3.cas-client-3.2.1 将cas-server-webapp-3 ...
- GDI与OpenGL与DirectX之间的区别
图形编程的几种技术对比: GDI,图形设备接口,MS开发的通用的windows系统图形编程接口,功能强涉及面广,一般的编程都用它.但是用来做多媒体开发就差强人意了 OPENGL是SGI开发的一套三维图 ...
- AppScan 8.0.3安全漏洞扫描总结
本文记录了通过AppScan 8.0.3工具进行扫描的安全漏洞问题以及解决方案, 1.使用SQL注入的认证旁路 问题描述: 解决方案: 一般通过XSSFIlter过滤器进行过滤处理即可,通过XSSFI ...
- php通过存储过程传入汉字参数并写入数据库
写入数据库,汉字为???样式的乱码,后根据网上介绍的方法,参数前加N,数据库汉字内容变成空白. 解决方法,在PHP中先转为base64,再在mysql中base64解码,前提先保证mysql中有bas ...
- bzoj 4319 cerc2008 Suffix reconstruction——贪心构造
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4319 如果字符集有 5e5 那么大的话,挨个填上去就行了.但只有26个字符,所以要贪心地尽量 ...
- 获取sonar扫描结果
api通过抓包获取 java 1.get和post方法 package com.tools.httpUtil; import java.io.BufferedReader; import java.i ...
- C# VS Java
摘要:C#的语言规范由Microsoft的Anders Hejlsberg与Scott Wiltamuth编写.在当前Microsoft天花乱坠的宣传中,对C#和C++.Java作一番比较总是很有趣的 ...
- 水仙花之java与c++的战争======
总结:同样在C++里可以运行正常的水仙花,在java里不行 为什么??是运算符优先级的问题吗: package com.a; //水仙花数 一个三位数 324:426/195 public class ...
- Linux下的Memcache安装,启动
一.linux安装memcache 1. 如果通过下载源码进行安装,则需要下载最新版本http://memcached.googlecode.com/files/memcached-1.4.13.ta ...
- 根据当前日期算前一年、前一月、前一天(java基础)
问题的本身没有什么难度,但是要想一下子找到一个现成的方法还真不是那么容易,本来以为java.util.Date中会有方法结果找了半天没找到,最后还是在Calendar中找到了,记下别忘了!! 核心:使 ...