JAVA 实现数据库备份(支持远程数据库)

package com.gaxf.paas.task;

import com.gaxf.paas.utils.DateUtil;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import java.io.*;

@Component
public class DatabaseTask {
    private static final Logger log = LoggerFactory.getLogger(DatabaseTask.class);
    private static final String PORT = ""; // 数据库端口
    private static final String HOST_IP = ""; // 数据库服务器所在ip 支持远程的 前提是本地服务器上有mysqldump 命令
    private static final String USERNAME = ""; //数据库登录名称
    private static final String PASSWORD = ""; // 数据库登录密码
    private static final String SAVE_PATH_WINDOWS = "D:\\database\\"; // 备份文件存储在本地的路径 windosw 服务器
    private static final String SAVE_PATH_LINUX = "/data/database/"; // 备份文件存储在本地的路径 linux 服务器


    // ======================== 所需要备份的数据库 ============================================
    private static final String JIMI_HYDRANT = "jimi-hydrant";
    private static final String PAAS = "paas";


    /**
     * 数据库备份
     */
    @Scheduled(cron = "0 0 3 * * ?")
    public void dbBackUpPaas() {
        try {
            dbBackUp(PAAS);
            dbBackUp(JIMI_HYDRANT);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /**
     * @param databaseName 需要备份的数据库的名称
     * @return
     */
    public static void dbBackUp(String databaseName) throws Exception {
        String fileName = databaseName + "_" + 当前日期 + ".sql";
        File saveFile = new File(savePath());
        if (!saveFile.exists()) {// 如果目录不存在
            saveFile.mkdirs();// 创建文件夹
        }

        PrintWriter printWriter = new PrintWriter(new OutputStreamWriter(new FileOutputStream(savePath() + fileName), "utf8"));
        Process process = Runtime.getRuntime().exec(getCommand(fileName, databaseName));
        BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(process.getInputStream(), "utf8"));
        String line;
        while ((line = bufferedReader.readLine()) != null) {
            printWriter.println(line);
        }
        printWriter.flush();
        if (process.waitFor() != 0) {
            log.info("数据库备份失败!");
        }
    }

    public static String getCommand(String fileName, String databaseName) {
        StringBuilder arg = new StringBuilder();
        arg.append("mysqldump ");
        arg.append(" -h" + HOST_IP);
        arg.append(" -P" + PORT);
        arg.append(" -u" + USERNAME);
        arg.append(" -p" + PASSWORD);
        arg.append(" --skip-opt ");
        arg.append("--add-drop-database ");
        arg.append("--routines ");
        arg.append("--triggers ");
        arg.append("--compress ");
        arg.append("-r");
        arg.append(savePath());
        arg.append(fileName);
        arg.append(" --databases " + databaseName);
        log.info(arg.toString());
        return arg.toString();
    }

    /**
     * 构建存储sql脚本的路径
     *
     * @return
     */
    public static String savePath() {
        String savePath;
        if (isWindows()) {
            savePath = SAVE_PATH_WINDOWS;
        } else {
            savePath = SAVE_PATH_LINUX;
        }
        return savePath;
    }

    /**
     * 判断服务所在系统为什么操作系统
     *
     * @return
     */
    public static boolean isWindows() {
        return System.getProperty("os.name").toLowerCase().contains("windows");
    }
}

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Java文件夹复制(远程复制(网络传输),用于远程备份文件)(支持文件夹,嵌套子文件夹) import java.io.*; import java.util.*; public class FileSelection { private File rootDirectory;//根目录 private File[] fileList;//文件目录下面的文件列表(包括目录,用于多次判断) private ArrayList fileArrayList; // 用于存储文件(只是文件)列表 //初始化参数 public FileSelection() { fileArrayList=new ArrayList(); rootDirectory = new File("Test"); rootDirectory.mkdir(); } //获得文件(不包括目录)的列表 public void initFileArrayList() { if (rootDirectory.isDirectory()) { //遍历目录下面的文件和子目录 fileList = rootDirectory.listFiles(); for (int i = 0; i < fileList.length; i++) { //如果是文件,添加到文件列表中 if(fileList[i].isFile()){ fileArrayList.add(fileList[i]); } //否则递归遍历子目录 else if (fileList[i].isDirectory()) { fileList[i].mkdir(); rootDirectory=fileList[i]; initFileArrayList(); } } } } //将文件信息添加到列表中 public void addFiles(File f){ fileArrayList.add(f); } //访问器返回文件列表 public ArrayList getFileArrayList() { return fileArrayList; } } -------------------- BackupClient.java package com.xinxin.Client; import java.io.*; import java.net.*; /** * * @author Administrator *@version 1.0 *BackupClient类实现文件的传输到服务器 */ public class BackupClient implements Runnable{ private int port;//服务器端口 private InetAddress ipAddress;//服务器IP地址 private Socket clientSocket;//客户端套接字 private InputStream inputStream;//网络输入流 private OutputStream outputStream;//网络输出流 private File file; //构造函数(获得服务器端IP地址和监听端口号) public BackupClient(InetAddress ipAddress,int port,File file){ this.ipAddress=ipAddress; this.port=port;

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值