db2数据库自动备份方法

步骤如下:
(1) 编写BAK.java,代码如下:(一周内周六完备、其他日期增量备份)
import java.util.Date;

public class BAK {
  public static void main(String[] args) throws Exception{
    Runtime runtime = Runtime.getRuntime();
    //断开数据库连接
    Process proc = runtime.exec("db2cmd /c db2 force application all");

    //只保留一天的备份
    //runtime.exec("del d://backup//db2bak//autobak//DATACTR.0// /S /F /Q");
    //runtime.exec("del d://backup//db2bak//autobak//RONE.0// /S /F /Q");
    //---------------------------------------------------------------
    //暂停n秒
    Thread.currentThread().sleep(5000);
    //关闭上述进程
    //proc.destroy();
    //--------------------------------------
    //暂停n秒,等待数据库连接断开
    //Thread.currentThread().sleep(5000);
    //备份
    //proc = runtime.exec("db2cmd db2 backup db DATACTR");
    //Thread.currentThread().sleep(5000);
    //proc.destroy();
    //--------------------------------------
    Date date = new Date();
    int dayOfTheWeek = date.getDay();
    if (dayOfTheWeek != 6){
        //不是周六,进行增量备份
//        proc = runtime.exec("db2cmd db2 backup db yndc incremental");
          proc = runtime.exec("db2cmd /c db2 backup db yndc incremental");
    }
    else{
        //是周六,进行完全备份
        proc = runtime.exec("db2cmd /c db2 backup db yndc");
    }
    //proc = runtime.exec("db2cmd db2 backup db gather");
    proc = runtime.exec("db2cmd /c db2 backup db codebase");
    proc = runtime.exec("db2cmd /c db2 backup db rone");
    //proc = runtime.exec("db2cmd db2 backup db datactr");

    //暂停5秒
    //Thread.currentThread().sleep(5000);
    //proc.destroy();
    //--------------------------------------
    //restart db2
    //proc = runtime.exec("db2start");
    //暂停5秒
    //Thread.currentThread().sleep(5000);
    //proc.destroy();
    //--------------------------------------
    runtime.exit(0);
  }
}

(2)编写run.bat,编译BAK.java并执行(注意需设置windows环境变量指向jdk的bin目录,在cmd下敲入命令"java"能找到这个命令,以支持编译和执行BAK.java
javac -deprecation BAK.java
java BAK

(3)通过windows的任务计划每天晚上定时调用run.bat进行数据库备份,譬如每晚22:00

(4)配合winzip软件可实现数据库的异机备份,定时将备份目录压缩至另一台机器的硬盘上(可映射成本地机器的网络硬盘。)

注意:db2 backup命令不支持将备份文件直接备份到网络硬盘上,将提示无法识别盘符
可根据需求选择离线备份或者在线备份。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值