JAVA代码实现数据库备份

简介: 在开发过程中,为了数据的安全性,我们经常需要定时备份一下数据库,这就需要在定时任务里,通过java代码实现数据库的备份。当然,这只是其中一种比较简单的实现方式。其他实现方式,会在后续进行探讨。
// 备份文件存放路径,我这里以当前日期作为文件夹
String root = JRelaxSystemConfigHelper.get("upload.folder.root", JRelaxCoreConfigHelper.getProperty("resource.upload.path"));
String uploadPath = JRelaxIOHelper.getInstance().resolvePath(root) + "mysqlbak/" + DateKit.format(new Date(), "yyyyMMdd");
String dbhost = "127.0.0.1";
String dbname = "dbname";//要备份的数据库名称
String dbusername = "dbusername";//数据库用户名
String dbpassword = "dbpassword";//数据库密码
System.err.println(StringKit.format("-------------获取到备份数据库: {0},{1},{2}", dbname, dbusername, dbpassword));
// 备份文件名称
String backName = dbname + "_" + dbhost + "_" + DateKit.format(new Date(), DateKit.HHMM) + ".sql";
String pathSql = uploadPath + "/" + backName;
try {
    File fileSql = new File(pathSql);
    // 创建备份sql文件
    if (!fileSql.getParentFile().exists()) {
        if (!fileSql.getParentFile().mkdirs()) {
            throw new IOException("文件夹创建失败");
        }
    }
    StringBuffer sb = new StringBuffer();
    sb.append("mysqldump");
    if(!"127.0.0.1".equals(dbhost))
        sb.append(" -h " + dbhost);
    sb.append(" -u" + dbusername);
    sb.append(" -p" + dbpassword);
    sb.append(" --databases " + dbname);
       //如果要过滤掉部分表不备份,可以通过--ignore-table参数
    String[] ignoreTables = { "sys_log", "sys_scheduler_log", "sys_file" , "sys_user"};
    for (String ignoreTable : ignoreTables) {
        sb.append(" --ignore-table=" + dbname + "." + ignoreTable);
    }

    sb.append(" >");
    sb.append(pathSql);
    System.err.println("cmd命令为:" + sb.toString());
    Runtime runtime = Runtime.getRuntime();
       //执行备份命令
    runtime.exec("cmd /c" + sb.toString());
       //打日志
    logService.info("数据库备份", StringKit.format("定时备份数据库成功:{0},{1},{2}", dbname, dbhost, backName), "schedule", new HandlerRequest());
} catch (Exception e) {
    e.printStackTrace();
    logService.info("数据库备份", StringKit.format("定时备份数据库失败:{0},{1},{2}_{3}", dbname, dbhost, backName,e.getMessage()), "schedule", new HandlerRequest());
}
目录
相关文章
|
17天前
|
设计模式 Java
Java设计模式:组合模式的介绍及代码演示
组合模式是一种结构型设计模式,用于将多个对象组织成树形结构,并统一处理所有对象。例如,统计公司总人数时,可先统计各部门人数再求和。该模式包括一个通用接口、表示节点的类及其实现类。通过树形结构和节点的通用方法,组合模式使程序更易扩展和维护。
Java设计模式:组合模式的介绍及代码演示
|
6天前
|
Java
java小工具util系列4:基础工具代码(Msg、PageResult、Response、常量、枚举)
java小工具util系列4:基础工具代码(Msg、PageResult、Response、常量、枚举)
20 5
|
8天前
|
Java API 开发者
探索Java中的Lambda表达式:简洁与强大的代码实践
本文深入探讨Java中Lambda表达式的定义、用法及优势,通过实例展示其如何简化代码、提升可读性,并强调在使用中需注意的兼容性和效率问题。Lambda作为Java 8的亮点功能,不仅优化了集合操作,还促进了函数式编程范式的应用,为开发者提供了更灵活的编码方式。
|
4天前
|
Java 开发者
探索Java中的Lambda表达式:简化你的代码之旅##
【8月更文挑战第62天】 Java 8的发布为开发者带来了诸多新特性,其中最引人注目的无疑是Lambda表达式。这一特性不仅让代码变得更加简洁,还极大地提升了开发的效率。本文将通过实际示例,展示如何利用Lambda表达式来优化我们的代码结构,同时探讨其背后的工作原理和性能考量。 ##
|
7天前
|
Java API 开发者
探索Java中的Lambda表达式:简化代码,提升效率
【9月更文挑战第27天】在Java 8中引入的Lambda表达式为编程带来了革命性的变化。通过简洁的语法和强大的功能,它不仅简化了代码编写过程,还显著提升了程序的执行效率。本文将深入探讨Lambda表达式的本质、用法和优势,并结合实例演示其在实际开发中的应用。无论你是Java新手还是资深开发者,都能从中获得启发,优化你的代码设计。
|
8天前
|
Java Linux Python
Linux环境下 代码java调用python出错
Linux环境下 代码java调用python出错
24 3
|
8天前
|
存储 Java 索引
使用java代码实现左右括号查找
使用java代码实现左右括号查找
|
9天前
|
算法 Java
java 概率抽奖代码实现
java 概率抽奖代码实现
|
17天前
|
Java 程序员 API
Java中的Lambda表达式:简化代码的秘密武器
在Java 8中引入的Lambda表达式是一种强大的编程工具,它可以显著简化代码,提高可读性。本文将介绍Lambda表达式的基本概念、优势以及在实际开发中的应用。通过具体示例,您将了解如何使用Lambda表达式来简化集合操作、线程编程和函数式编程。让我们一起探索这一革命性的特性,看看它是如何改变Java编程方式的。
25 4
|
17天前
|
Java 开发者
探索Java中的Lambda表达式:简化你的代码
【8月更文挑战第49天】在Java 8的发布中,Lambda表达式无疑是最令人兴奋的新特性之一。它不仅为Java开发者提供了一种更加简洁、灵活的编程方式,而且还极大地提高了代码的可读性和开发效率。本文将通过实际代码示例,展示如何利用Lambda表达式优化和重构Java代码,让你的编程之旅更加轻松愉快。
下一篇
无影云桌面