>데이터 베이스 >MySQL 튜토리얼 >java定时备份数据库_MySQL

java定时备份数据库_MySQL

WBOY
WBOY원래의
2016-06-01 13:08:121115검색

java数据库定时备份,这里是以mysql为例:

BackupDb.java(数据库备份类)

public class BackupDb {
 public String backup() throws IOException{
  String user = "root"; //数据库的用户名
  String password = "root";//数据库的密码 
  String database = "database";//要备份的数据库名 
  Date date = new Date();
  SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");
  String filepath = "d://jinsus"+sdf.format(date)+".sql";
  File file = new File("d://","jinsus"+sdf.format(date)+".sql");
  if(!file.exists()){
   file.createNewFile();  
  }
  String stmt1 = "mysqldump " + database +" -h 127.0.0.1 "+ " -u " + user + " -p" +
  password + " --default-character-set=gbk --result-file=" + filepath;
  try {
    Runtime.getRuntime().exec(stmt1);
    System.out.println("已经保存到 " + filepath + " 中");
  } catch (IOException e) {
   e.printStackTrace();
  }
  return filepath;
 }
}

TimerUse.java(定时及测试类)

public class TimerUse {
 public static void main(String[] args) {
  PickTask picktask = new PickTask();
  picktask.start(1, 60); // 每60秒执行一次
 }
}

class PickTask {
 private Timer timer;
 private  TimerTask task = new TimerTask() {
  public void run() {
   Date date = new Date();
   SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
   String beginDate = sdf.format(date);
   String beginTime = beginDate.substring(11, 16);
   System.out.println("开始时间:"+beginDate);

   BackupDb bdb = new BackupDb();
      // 设定备份时间
   if (beginTime.equals("16:39")) {
    try {
     bdb.backup(); // 执行文件备份
     String dbName = bdb.backup().toString(); // 取出备份的文件名字
     String path = "d://";
     int nameNo = dbName.lastIndexOf("//");
     //判断文件是否存在,如果存在,则备份成功,如果不存在则备份不成功需要重新备份
     File file = new File(path, dbName.substring(nameNo + 1,
       dbName.length()));
     if (file.exists()){
           system.out.println("备份成功");

     }else{

            system.out.println("备份失败,重新备份");
           //在备份未成功的情况下重新备份
      new PickTask().start(1, 1);
     }

    } catch (FileNotFoundException e) {
     System.out.println("can not find the file");
    } catch (IOException e) {
     e.printStackTrace();
    }
   }else{
    System.out.println("时间还不到呢,不要着急哦!");
   }
  }
 };

      //start 方法不能少,主要是schedule方法
 public void start(int delay, int internal) {
  timer.schedule(task, delay * 1000, internal * 1000);
 }
}

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.