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; | |
/** 说明:数据备份还原 | |
* 作者:fhadmin | |
* from www.fhadmin.cn | |
*/ | |
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; | |
public void setBackupService(BackUpServiceI service){ | |
this.service=service; | |
} | |
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"; | |
} | |
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(); | |
} | |
/** | |
* 数据的恢复 | |
*/ | |
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);*/ | |
} | |
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; | |
} | |
} |
java mysql 数据库备份和还原操作
Java
391
0
0
2022-05-14
登录后可点赞和收藏
登录后可点赞和收藏