java文件备份同步,JAVA实现MySQL数据库备份及恢复

包 com.xxx.core.db; importjava.io。 * ;

公共 类 MySQLDatabaseBackup {

公共 静态 布尔 exportDatabase(字符串hostIP,字符串userName,字符串密码,字符串savePath,字符串fileName,字符串databaseName)throws InterruptedException {

文件saveFile = 新建 File(savePath);

如果(!saveFile.exists()){// 如果目录不存在

saveFile.mkdirs(); // 创建文件夹

}

如果(!savePath.endsWith(File.separator)){

savePath = savePath + File.separator;

}

PrintWriter printWriter = null ;

BufferedReader bufferedReader = null ;

试试

printWriter = 新建 PrintWriter(new OutputStreamWriter(新建 FileOutputStream(savePath + fileName)," utf8" )));

流程 = Runtime.getRuntime()。执行(" mysqldump-h" + hostIP +"-u" +用户名+"-p" +密码+"--set-charset = UTF8" + databaseName);

InputStreamReader inputStreamReader = 新建 InputStreamReader(process.getInputStream()," utf8" );

bufferedReader = 新 BufferedReader(inputStreamReader);

字符串行;

而((line = bufferedReader.readLine())!= null ){

printWriter.println(行);

}

printWriter.flush();

如果(process.waitFor()== 0){// 0表示线程正常终止。

返回 true ;

}

} catch (IOException e){

e.printStackTrace();

} 最终

试试

如果(bufferedReader!= null ){

bufferedReader.close();

}

如果(printWriter!= null ){

printWriter.close();

}

} catch (IOException e){

e.printStackTrace();

}

}

返回 false ;

}

公共 静态 布尔 importDatabase(字符串hostIP,字符串hostPort,字符串userName,字符串密码,字符串importFilePath,字符串sqlFileName,字符串databaseName){

文件imporFile = 新建 File(importFilePath);

如果(!imporFile.exists()){

imporFile.mkdirs();

}

如果(!importFilePath.endsWith(File.separator)){

importFilePath = importFilePath + File.separator;

}

试试

// 创建数据库:mysqladmin-h 192.168.1.40-u root-proot create icqr

字符串createDB =" mysqladmin-h" + hostIP +"-u" +用户名+"-p" +密码+"创建" + databaseName;

Runtime.getRuntime()。执行(createDB);

// 写数据:mysql-h127.0.0.1-uroot-P3306-p测试D:\\\\ backupDatabase \\\\

流程= Runtime.getRuntime()。执行(" cmd/C" +" mysql-h" + hostIP +"-P" + hostPort +"-u" +用户名+"-p" +密码+"" +数据库名+" \ lt;" + importFilePath + sqlFileName);

如果(process.waitFor()== 0 ){

返回 true ;

}

} catch (IOException e){

e.printStackTrace();

} catch (InterruptedException e){

e.printStackTrace();

}

返回 false ;

}

public 静态 void main(字符串[] args){

布尔结果 = true ;

// result = importDatabase(" 127.0.0.1"," 3306","根","密码"," D:\\\\\\\\ backupDatabase"," 2014-10-14.sql"," databaseName");

尝试 {

结果 = exportDatabase(" 127.0.0.1"," root"," password"," D:\\\\\\\\ backupDatabase \\\\"," backup.sql"," databaseName" );

} catch (异常e){

e.printStackTrace();

}

如果 (结果){

System.out.println("数据库备份成功" );

} 其他

System.out.println("数据库备份失败!!" );

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java文件夹复制(远程复制(网络传输),用于远程备份文件)(支持文件夹,嵌套子文件夹) import java.io.*; import java.util.*; public class FileSelection { private File rootDirectory;//根目录 private File[] fileList;//文件目录下面的文件列表(包括目录,用于多次判断) private ArrayList fileArrayList; // 用于存储文件(只是文件)列表 //初始化参数 public FileSelection() { fileArrayList=new ArrayList(); rootDirectory = new File("Test"); rootDirectory.mkdir(); } //获得文件(不包括目录)的列表 public void initFileArrayList() { if (rootDirectory.isDirectory()) { //遍历目录下面的文件和子目录 fileList = rootDirectory.listFiles(); for (int i = 0; i < fileList.length; i++) { //如果是文件,添加到文件列表中 if(fileList[i].isFile()){ fileArrayList.add(fileList[i]); } //否则递归遍历子目录 else if (fileList[i].isDirectory()) { fileList[i].mkdir(); rootDirectory=fileList[i]; initFileArrayList(); } } } } //将文件信息添加到列表中 public void addFiles(File f){ fileArrayList.add(f); } //访问器返回文件列表 public ArrayList getFileArrayList() { return fileArrayList; } } -------------------- BackupClient.java package com.xinxin.Client; import java.io.*; import java.net.*; /** * * @author Administrator *@version 1.0 *BackupClient类实现文件的传输到服务器 */ public class BackupClient implements Runnable{ private int port;//服务器端口 private InetAddress ipAddress;//服务器IP地址 private Socket clientSocket;//客户端套接字 private InputStream inputStream;//网络输入流 private OutputStream outputStream;//网络输出流 private File file; //构造函数(获得服务器端IP地址和监听端口号) public BackupClient(InetAddress ipAddress,int port,File file){ this.ipAddress=ipAddress; this.port=port;

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值