Java实现远程Mysql数据库备份导出数据

Java备份数据库到SQL文件
本文介绍了一种使用Java调用Shell脚本备份数据库的方法,通过读取application.properties配置文件中的命令,执行备份数据到SQL文件的过程。涉及的步骤包括调用接口、获取配置命令和执行execCmd方法。

本文仅供参考!!!

通俗的讲就是3步:1-调接口,2-获取配置文件的命令,3-调取execCmd方法 执行

配置配件:(本次测试,backupsData脚本放在了服务器的/opt目录下)

   /**
     * application.properties文件配置
     */
cmd.executiveOrderSqlData=/opt/backupsData.sh

1.controller

   /**
     * 注解读取application.properties文件配置
     */
    @Value("${cmd.executiveOrderSqlData}")//备份数据语句命令
    private String executiveOrderSqlData;
    /**
     * 备份数据
     */
    @RequestMapping(value = "/conf/backupsData" ,method = RequestMethod.GET)
    @ResponseBody
    public Object backupsData(HttpServletRequest request) throws IOException{
        sysService.backupsData(executiveOrderSqlData);
    }

2.service

    /**
     * 备份数据 导出sql表语句和数据
     */
    public String  backupsData(String executiveOrder){
        return  execCmd(executiveOrder);
    }

execCmd方法:

    /**
     * 执行命令
     */
    private String  execCmd(String cmd){
        logger.info("cmd ======================:"+cmd);

        StringBuilder sb=new StringBuilder();
        try {
            Process p = Runtime.getRuntime().exec(cmd);
            p.waitFor();
            BufferedReader reader = new BufferedReader(new InputStreamReader(p.getInputStream()));
            String line="";
            while ((line = reader.readLine()) != null) {
                sb.append(line);
            }
        }
        catch(Exception e1) {}
        return  sb.toString();
    }

脚本命令:

代码

#!/bin/bash
/usr/bin/mysqldump -uusername -ppassword DatabaseName > /opt/DatabaseName_$(date +%Y%m%d).sql

username:数据库用户名

password:数据库密码

DatabaseName:数据库名字

对应字段自己修改成自己

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我先来一碗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值