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());
}
目录
相关文章
|
5天前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
|
5天前
|
XML Java 数据库连接
性能提升秘籍:如何高效使用Java连接池管理数据库连接
在Java应用中,数据库连接管理至关重要。随着访问量增加,频繁创建和关闭连接会影响性能。为此,Java连接池技术应运而生,如HikariCP。本文通过代码示例介绍如何引入HikariCP依赖、配置连接池参数及使用连接池高效管理数据库连接,提升系统性能。
27 5
|
19天前
|
XML 安全 Java
Java反射机制:解锁代码的无限可能
Java 反射(Reflection)是Java 的特征之一,它允许程序在运行时动态地访问和操作类的信息,包括类的属性、方法和构造函数。 反射机制能够使程序具备更大的灵活性和扩展性
33 5
Java反射机制:解锁代码的无限可能
|
15天前
|
jenkins Java 测试技术
如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例详细说明
本文介绍了如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例,详细说明了从 Jenkins 安装配置到自动构建、测试和部署的全流程。文中还提供了一个 Jenkinsfile 示例,并分享了实践经验,强调了版本控制、自动化测试等关键点的重要性。
48 3
|
21天前
|
存储 安全 Java
系统安全架构的深度解析与实践:Java代码实现
【11月更文挑战第1天】系统安全架构是保护信息系统免受各种威胁和攻击的关键。作为系统架构师,设计一套完善的系统安全架构不仅需要对各种安全威胁有深入理解,还需要熟练掌握各种安全技术和工具。
59 10
|
16天前
|
分布式计算 Java MaxCompute
ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
|
17天前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
31 3
|
15天前
|
Java
Java代码解释++i和i++的五个主要区别
本文介绍了前缀递增(++i)和后缀递增(i++)的区别。两者在独立语句中无差异,但在赋值表达式中,i++ 返回原值,++i 返回新值;在复杂表达式中计算顺序不同;在循环中虽结果相同但使用方式有别。最后通过 `Counter` 类模拟了两者的内部实现原理。
Java代码解释++i和i++的五个主要区别
|
17天前
|
存储 Java 关系型数据库
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践,包括连接创建、分配、复用和释放等操作,并通过电商应用实例展示了如何选择合适的连接池库(如HikariCP)和配置参数,实现高效、稳定的数据库连接管理。
34 2
|
17天前
|
Java 数据库连接 数据库
如何构建高效稳定的Java数据库连接池,涵盖连接池配置、并发控制和异常处理等方面
本文介绍了如何构建高效稳定的Java数据库连接池,涵盖连接池配置、并发控制和异常处理等方面。通过合理配置初始连接数、最大连接数和空闲连接超时时间,确保系统性能和稳定性。文章还探讨了同步阻塞、异步回调和信号量等并发控制策略,并提供了异常处理的最佳实践。最后,给出了一个简单的连接池示例代码,并推荐使用成熟的连接池框架(如HikariCP、C3P0)以简化开发。
38 2