栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java实现备份MySQL数据库Linux和Windows

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java实现备份MySQL数据库Linux和Windows

最近无聊,闲来无事,就喜欢研究。于是想搞一下数据库的自动备份。
Windows和Linux通用。这是一种比较麻烦的备份,其实一般数据库的备份和还原都是通过shell完成的。
至于这里的数据库还原太麻烦,需要修改配置文件,而且基本不用(主要还是自己不太熟悉,讲不清楚)。
数据库备份代码:

    public  boolean databaseBack(String mysqlDump,String hostIP,String port,String user,String password,String dataOrTableName,String savePath,String exportFileName) throws IOException, InterruptedException {
        StringBuilder sb = new StringBuilder();
        String[] cmd = new String[3];
        if (isLinuxSystem()){
            cmd[0]="/bin/sh";
            cmd[1]="-c";
        }else{
            cmd[0]="cmd";
            cmd[1]="/c";
        }
        if (mysqlDump.endsWith(File.separatorChar+"")){
            sb.append(mysqlDump+"mysqldump -h");
        }else{
            sb.append(mysqlDump+File.separatorChar+"mysqldump -h");
        }
        sb.append(hostIP+" -P");
        sb.append(port+" -u");
        sb.append(user+" -p");
        sb.append(password+" ");
        sb.append(dataOrTableName+" > ");
        if (!savePath.endsWith(File.separatorChar+"")){
            sb.append(savePath+File.separatorChar);
        }else {
            sb.append(savePath);
        }
        sb.append(exportFileName);
        System.out.println(sb);
        cmd[2] = sb.toString();
        Process exec = Runtime.getRuntime().exec(cmd);
        if(exec.waitFor()!=0){
            return false;
        }
        return true;
    }

//判断系统是否是Linux
    public boolean isLinuxSystem(){
        if(System.getProperty("os.name").toLowerCase().contains("linux")){
            return true;
        }
        return false;
    }


数据导出成功,这是Linux上的

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/841566.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号