Java-Java调用mysqldump进行数据库备份
1 public ResultData backupDatabase(Integer type) {
2 // 构建备份sql的文件名
3 String sqlFileName = "test" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()) + ".sql";
4 PrintWriter printWriter = null;
5 BufferedReader bufferedReader = null;
6
7 try {
8 // 查询所需备份的表(备份的具体哪些表由数据库配置)
9 List<SwBackUpTable> backUpTableList = dataManagerDao.getBackupTables();
10 StringBuilder stringBuilder = new StringBuilder("");
11
12 // 所需备份的表的拼接字符串
13 for (SwBackUpTable swBackUpTable : backUpTableList) {
14 stringBuilder.append(" ").append(swBackUpTable.getTableName());
15 }
16 String backupTables = stringBuilder.toString();
17
18 // 构建备份sql文件路径
19 File savePath = new File(backupSqlPath);
20 if (!savePath.exists()) {
21 // 创建文件夹
22 savePath.mkdirs();
23 }
24 String sqlPath = backupSqlPath + "/" + sqlFileName;
25
26 //导出指定数据库指定表的结构和数据
27 String command = mysqlPath + backupTables;
28 System.out.println("mysql执行指令:" + command);
29 Process process = Runtime.getRuntime().exec(command);
30
31 printWriter = new PrintWriter(new OutputStreamWriter(new FileOutputStream(sqlPath), "utf8"));
32 InputStreamReader inputStreamReader = new InputStreamReader(process.getInputStream(), "utf8");
33 bufferedReader = new BufferedReader(inputStreamReader);
34
35 String line;
36 while ((line = bufferedReader.readLine()) != null) {
37 printWriter.println(line);
38 }
39 printWriter.flush();
40
41 //0 表示线程正常终止。
42 if (process.waitFor() == 0) {
43 System.out.println("备份数据成功");
44 }
45 System.out.println("数据备份路径==>" + sqlPath);
46
47 // 备份记录
48 BackUpRecords record = new SwBackUpRecords();
49 record.setName(sqlFileName);
50 record.setTables(backupTables);
51 record.setSource(type);
52 record.setPath(sqlPath);
53 record.setBackupTime(new Date());
54 dataManagerDao.insertRecords(record);
55
56 return ResultData.success("备份成功");
57 } catch (Exception e) {
58 e.printStackTrace();
59 return ResultData.success("备份失败");
60 } finally {
61 //关闭流
62 try {
63 if (bufferedReader != null) {
64 bufferedReader.close();
65 }
66 if (printWriter != null) {
67 printWriter.close();
68 }
69 } catch (IOException e) {
70 e.printStackTrace();
71 }
72 }
73 }
以上代码中,type字段为业务所需,无需关注.
mysqlPath: /user/local/mysql/mysql-8.0/bin/mysqldump -uroot -proot Test
Test为数据库名
backupSqlPath:服务器存放备份sql的文件夹路径(如:/home/date/backupSql)
Java-Java调用mysqldump进行数据库备份的更多相关文章
- mysqldump 把数据库备份到异地的服务器
原文:http://www.open-open.com/code/view/1420121471484 这个方法可以把通过mysqldump 把本地数据库备份到远端主机, 中间数据的传输通过 ssh ...
- JSP 实现 之 调用java方法实现MySQL数据库备份和恢复
package cn.qm.db; import java.io.BufferedReader; import java.io.DataInputStream; import java.io.IOEx ...
- windows下Java调用mysql的客户端备份和恢复
这种东西没啥好聊的,其实就是Java执行dos界面下的命令,不过有些要注意就是了,真实dos下面的命令和java调用的windows系统的接口其实还是有一点不同. /** * @param hostI ...
- java 实现mysql数据库备份
package com.itenp.gen.action; import java.io.BufferedReader; import java.io.FileInputStream; import ...
- Java实现MySQL数据库备份(二)
权声明:本文为博主原创文章,未经博主允许不得转载. 博客<Java实现MySQL数据库备份(一)>使用I/O流的方式实现了MySQL数据库的备份,这种方法比较繁杂,下面介绍另一种备份MyS ...
- Java实现MySQL数据库备份(一)
下班了,利用闲暇时间总结一下如何使用Java语言实现MySQL数据库备份: import java.io.BufferedReader; import java.io.File; import jav ...
- Java实现mysql数据库备份
Runtime是一个与JVM运行时环境有关的类,这个类是Singleton的. Runtime.getRuntime()可以取得当前JVM的运行时环境,这也是在Java中唯一一个得到运行时环境的方法. ...
- Java达到MySQL数据库备份(两)
博客<Java实现MySQL数据库备份(一)>使用I/O流的方式实现了MySQL数据库的备份,这样的方法比較繁杂.以下介绍还有一种备份MySQL数据库的方法: import java.io ...
- Java实现Oracle数据库备份
今天将很早就实现的一个Oracle数据库备份功能粘贴出来,这个功能是在大学做阶段设计时写的: import java.io.File; import java.io.IOException; /** ...
- jsp页面:js方法里嵌套java代码(是操作数据库的),如果这个js 方法没被调用,当jsp页面被解析的时候,不管这个js方法有没有被调用这段java代码都会被执行?
jsp页面:js方法里嵌套java代码(是操作数据库的),如果这个js 方法没被调用,当jsp页面被解析的时候,不管这个js方法有没有被调用这段java代码都会被执行? 因为在解析时最新解析的就是JA ...
随机推荐
- 【学习笔记】QT从入门到实战完整版(菜单栏、工具栏、浮动窗口、状态栏、中心部件)(3)
QMainWindow QMainWindow 是一个为用户提供主窗口程序的类,包含以下几种类型部件,是许多应用程序的基础. 示例代码 void MainWindow::test() { // --- ...
- 通过一个示例形象地理解C# async await 非并行异步、并行异步、并行异步的并发量控制
前言 接上一篇 通过一个示例形象地理解C# async await异步 我在 .NET与大数据 中吐槽前同事在双层循环体中(肯定是单线程了)频繁请求es,导致接口的总耗时很长.这不能怪前同事,确实难写 ...
- websocket-sharp 实现websocket
第一步,使用VS创建一个应用程序 第二步,添加引用 websocket-sharp DLL文件,或者NuGet程序包中添加 第三部,创建Laputa 类 using WebSocketSharp; u ...
- ubuntu卸载eigen
1.sudo updatedb 2.locate eigen3 3.手动删除
- C++练习-1 简单输入输出
首先完整代码如下: #include <iostream> #include <string> using namespace std; int main() { int on ...
- 一文详解SpEL表达式注入漏洞
摘要:本文介绍了SpEL表达式以及常见的SpEL注入攻击,详细地介绍了部分漏洞攻击实例以及常用的漏洞检测与防御手段. 本文分享自华为云社区<SpEL表达式注入漏洞分析.检查与防御>,作者: ...
- 【模板】动态树(Link Cut Tree)
模板 \(\text{Code}\) #include <cstdio> #include <iostream> #define IN inline #define RE re ...
- vue-seamless-scroll滚动加点赞衔接处数据不同步问题
VUE使用vue-seamless-scroll自动滚动加点赞,因为有两个overhidden导致点击不同同步dom,在代码中会出现两处vue-seamless-scroll上下悬接,悬接处点赞触发没 ...
- swiper弹出窗口居中效果css
position: absolute; width: 800px; left: 50%; top: 50%; transform: translate(-50%, -50%);
- 免费ASP空间
free免费asp空间的申请方法: free免费asp空间的ftp使用方法: sise.host3v.vip/1