java项目服务器数据库备份,Java web 项目中对数据库备份和恢复

说白了,仍是去调用cmd实现数据库的备份和还原功能。html

备份:java

mysqldump -hserverUrl -uusername -ppassword dbname > savePath

还原:mysql

mysql -hserverUrl -uusername -ppassword dbname < filePath

13ddb0d43c385c03e5d48b48b04a2676.png

1810508e7046517768e69e5406497f74.png

package com.cxx.backupdb;

import java.io.*;

import java.text.SimpleDateFormat;

import java.util.Date;

/**

* @Author: cxx

* 数据库备份与还原

* @Date: 2018/4/28 19:56

*/

public class DbOperate {

/**

* 备份数据库db

* @param root

* @param pwd

* @param dbName

* @param backPath

* @param backName

*/

public static void dbBackUp(String root,String pwd,String dbName,String backPath,String backName) throws Exception {

String pathSql = backPath+backName;

File fileSql = new File(pathSql);

//建立备份sql文件

if (!fileSql.exists()){

fileSql.createNewFile();

}

//mysqldump -hlocalhost -uroot -p123456 db > /home/back.sql

StringBuffer sb = new StringBuffer();

sb.append("mysqldump");

sb.append(" -h60.115.212.196");

sb.append(" -u"+root);

sb.append(" -p"+pwd);

sb.append(" "+dbName+" >");

sb.append(pathSql);

System.out.println("cmd命令为:"+sb.toString());

Runtime runtime = Runtime.getRuntime();

System.out.println("开始备份:"+dbName);

Process process = runtime.exec("cmd /c"+sb.toString());

System.out.println("备份成功!");

}

/**

* 恢复数据库

* @param root

* @param pwd

* @param dbName

* @param filePath

* mysql -hlocalhost -uroot -p123456 db < /home/back.sql

*/

public static void dbRestore(String root,String pwd,String dbName,String filePath){

StringBuilder sb = new StringBuilder();

sb.append("mysql");

sb.append(" -h60.115.212.196");

sb.append(" -u"+root);

sb.append(" -p"+pwd);

sb.append(" "+dbName+"

sb.append(filePath);

System.out.println("cmd命令为:"+sb.toString());

Runtime runtime = Runtime.getRuntime();

System.out.println("开始还原数据");

try {

Process process = runtime.exec("cmd /c"+sb.toString());

InputStream is = process.getInputStream();

BufferedReader bf = new BufferedReader(new InputStreamReader(is,"utf8"));

String line = null;

while ((line=bf.readLine())!=null){

System.out.println(line);

}

is.close();

bf.close();

} catch (IOException e) {

e.printStackTrace();

}

System.out.println("还原成功!");

}

public static void main(String[] args) throws Exception {

String backName = new SimpleDateFormat("yyyy-MM-dd-HH-mm-ss").format(new Date())+".sql";

DbOperate.dbBackUp("root","123456","ks","F:/",backName);

dbRestore("root","123456","ks","F://2018-04-30-19-28-28.sql");

}

}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值