之前对电脑重装了一下,结果IDEA的项目目录没有备份,导致有几个平时会拿来参考的项目都丢失了,尤其有一个自己写的Springboot项目当初没有备份,这次是彻底无缘再见了,有的东西可以对外(开源)的还是放在博客园这些地方记录一下比较不错,偶尔再遇到这样的问题Ctrl+C&Ctrl+V即可解决了。
这回记录一下Springboot实现对数据库进行一个备份和通过备份数据对数据库进行恢复。当然不限于Springboot,对数据库备份还原中的代码,Java 相关的都可以使用。
备份通过命令行对数据库导出到指定目录即可。我这里是一个Get请求,页面需要展示备份文件名称、大小和备份时间,代码中使用的log是Slf4j,最终界面效果如图:
代码对我的原代码有所改动,关于备份文件的存放目录,我配置在了application.properties配置文件中,通过一个配置类ProjectUrlConfig去获取,代码中的projectUrlConfig.getBackPath()即为文件目录,与fileName拼接成完整的路径。
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
/* 备份数据库 */
@GetMapping("backupSQL")
public ModelAndView backupSQL(Map<String, Object> map){
String fileName = "backup_" + new Date().getTime() + ".sql";
String cmd = "mysqldump -uroot -p123456 dbName > " + projectUrlConfig.getBackPath() + fileName; //-u后的root为mysql数据库用户名,-p后接的123456为该用户密码,注意不要有空格;dbName填写需要备份数据的数据库名称,大于号后接生成文件路径
try {
Runtime.getRuntime().exec(cmd);
}catch (Exception e){
log.error("【备份数据库】失败:{}", e.getMessage());
map.put("msg", e.getMessage());
return new ModelAndView("common/error", map);
}
log.info("【备份数据库】成功,SQL文件:{}", fileName);
map.put("msg","备份数据库成功");return new ModelAndView("common/success", map);
}
|
恢复数据库
备份虽然在cmd命令行中使用 “mysql -uroot -p123456 dbName < SQL文件路径” 可以对数据库还原,尝试使用时没有发现报错但数据库并未还原,最后通过OutputStreamWriter 来实现。
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
@GetMapping("rollback")
public ModelAndView rollback(@RequestParam("filename") String fileName, Map<String, Object> map){
String path = projectUrlConfig.getBackPath() + fileName;
try {
Runtime runtime = Runtime.getRuntime();
Process process = runtime.exec("mysql -uroot -p123456 --default-character-set=utf8 dbName");
OutputStream outputStream = process.getOutputStream();
FileInputStream fis = new FileInputStream(path);
InputStreamReader isr = new InputStreamReader(fis, "utf-8");
BufferedReader br = new BufferedReader(isr);
String str = null;
StringBuffer sb = new StringBuffer();
while ((str = br.readLine()) != null) {
sb.append(str + "\\r\\n");
}
str = sb.toString();
OutputStreamWriter writer = new OutputStreamWriter(outputStream,"utf-8");
writer.write(str);
writer.flush();
if(writer!=null){
writer.close();
}
if(br!=null){
br.close();
}
if(isr!=null){
isr.close();
}
if(fis!=null){
fis.close();
}
if(outputStream!=null){
outputStream.close();
}
}catch (Exception e){
log.error("【还原数据库】失败:{}", e.getMessage());
map.put("msg", e.getMessage());
return new ModelAndView("common/error", map);
}
log.info("【还原数据库】成功,还原文件:{}", fileName);
map.put("msg","还原数据库成功");return new ModelAndView("common/success", map);
}
|
以上即可对数据库进行备份与恢复,但是也只是适用于较小的数据库。
参考文章:https://blog.csdn.net/duli3554197/article/details/89468758
总结
到此这篇关于Springboot 实现数据库备份还原的文章就介绍到这了,更多相关Springboot 数据库备份还原内容请搜索快网idc以前的文章或继续浏览下面的相关文章希望大家以后多多支持快网idc!
原文链接:https://www.cnblogs.com/shenyuanfeng/p/13698456.html
相关文章
- 64M VPS建站:能否支持高流量网站运行? 2025-06-10
- 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10
- 64M VPS建站:怎样优化以提高网站加载速度? 2025-06-10
- 64M VPS建站:是否适合初学者操作和管理? 2025-06-10
- ASP.NET自助建站系统中的用户注册和登录功能定制方法 2025-06-10
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
-
2025-05-27 62
-
创建个人或企业网站:租用虚拟专用服务器(VPS)还是物理服务器?
2025-06-05 58 -
2025-05-25 69
-
2025-05-25 57
-
2025-05-25 98


