java 备份数据库 springboot

27 篇文章 1 订阅
4 篇文章 2 订阅
   Logger log = LoggerFactory.getLogger(this.getClass());
    //数据库地址
	@Value("${spring.datasource.url}")
	String url;
    //用户名
	@Value("${spring.datasource.username}")
	String username;
    //密码
	@Value("${spring.datasource.password}")
	String password;
    //需要备份的数据库 可以多个, 多个使用逗号分隔
	@Value("${dbNames}")
	String dbNames;
   //截取IP
	private String getHost(){
		return url.substring(13,27);
	}

	@GetMapping(value = "/exportSQL")
	public String exportSQL(){
		String filePath = "";
		File file = new File(filePath);
		if (!file.exists()){
			file.mkdirs();
		}
		String host = getHost();
		List<String> strings = Arrays.asList(dbNames.split(","));
		strings.stream().forEach(dbName -> {
			try {
				log.info("dbNme--->"+dbName);
                //linux下保存备份的路径 
				String sqlBackPath = "/code/dbback/";
               //保存的文件名称 DateUtility.getCurrentDate()是年月日
				String fileName =  DateUtility.getCurrentDate() + "_" + dbName + ".sql";
				StringBuilder sb = new StringBuilder();
				sb.append("mysqldump")
				.append(" -h")
				.append(host)
				.append(" -u")
				.append(username)
				.append(" -p'")
				.append(password +"'") //我的密码有特殊符号  所以使用了单引号处理
				.append(" "+dbName)
				.append(" > "+sqlBackPath)
				.append(fileName);
				log.info("sb-->"+sb.toString());
                //linux下的命令  windows下使用 String[] command = { "cmd", "/c", sb.toString()}
				String[] command = { "/bin/sh", "-c", sb.toString() };
				Process process = Runtime.getRuntime().exec(command);
				if (0 == process.waitFor()){
					log.info("数据库备份成功,保存路径是: "+sqlBackPath);
				}else {
					log.info("process.waitFor()=="+process.waitFor());
				}
			}catch (Exception e){
				log.error("io异常",e);
			}
		});
		return "ok";
	}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值