配置文件中的信息

sqlurl=C://Program Files (x86)//MySQL//MySQL Server 5.0//bin//mysqldump -h localhost -uroot -pwjg user
path=F:/test.sql
backuptime=16:34:00

备份数据库

public class TestMysql {
//读取配置文件中的信息
//MySql的安装bin目录路径和dump等参数
static String sqlurl=GetProperty.getPropertyByName("property","sqlurl");
//保存备份文件的路径及名称
static String path=GetProperty.getPropertyByName("property","path");

public TestMysql(){
backup(); // 备份数据库
System.out.println("备份数据库成功!");
}

public static void backup(){
try {
Runtime rt =Runtime.getRuntime(); //返回与当前的Java应用程序的运行时对象
// 调用 调用mysql的安装目录的命令
Process child = rt.exec(sqlurl);
// 设置导出编码为utf-8。这里必须是utf-8
// 把进程执行中的控制台输出信息写入.sql文件,即生成了备份文件。注:如果不对控制台信息进行读出,则会导致进程堵塞无法运行
InputStream in = child.getInputStream();// 控制台的输出信息作为输入流
InputStreamReader xx = new InputStreamReader(in, "utf-8");
// 设置输出流编码为utf-8。这里必须是utf-8,否则从流中读入的是乱码
String inStr;
StringBuffer sb = new StringBuffer("");
String outStr;
// 组合控制台输出信息字符串
BufferedReader br = new BufferedReader(xx);
while ((inStr = br.readLine()) != null) {
sb.append(inStr + "\r\n");
}
outStr = sb.toString();
// 要用来做导入用的sql目标文件:
FileOutputStream fout = new FileOutputStream(path);
OutputStreamWriter writer = new OutputStreamWriter(fout, "utf-8");
writer.write(outStr);
writer.flush();
in.close();
xx.close();
br.close();
writer.close();
fout.close();
System.out.println("");
} catch (Exception e) {
e.printStackTrace();
}
}
}

调用要执行的内容

public class NFDFlightDataTimerTask extends TimerTask {

private static Logger log = Logger.getLogger(NFDFlightDataTimerTask.class);
@Override
public void run() {
try {
//在这里写你要执行的内容
  new TestMysql();

  } catch (Exception e) {
  log.info("-------------解析信息发生异常--------------");
   }
  }

}

在 TimerManager 这个类里面,大家一定要注意 时间点的问题。如果你设定在凌晨2点执行任务。但你是在2点以后
发布的程序或是重启过服务,那这样的情况下,任务会立即执行,而不是等到第二天的凌晨2点执行。为了,避免这种情况
发生,只能判断一下,如果发布或重启服务的时间晚于定时执行任务的时间,就在此基础上加一天。

public class TimerManager {
//时间间隔 一天时间
private static final long PERIOD_DAY = 24 * 60 * 60 * 1000;

public TimerManager() {

//获取并处理配置文件中的时间
String backuptime=GetProperty.getPropertyByName("property","backuptime");
String[] time=backuptime.split(":");
int hours=Integer.parseInt(time[0]);
int minute=Integer.parseInt(time[1]);
 int second=Integer.parseInt(time[2]);

Calendar calendar = Calendar.getInstance();

/*** 定制每日2:00执行方法 ***/
calendar.set(Calendar.HOUR_OF_DAY,hours);
calendar.set(Calendar.MINUTE, minute);
calendar.set(Calendar.SECOND, second);

Date date=calendar.getTime(); //第一次执行定时任务的时间

//如果第一次执行定时任务的时间 小于 当前的时间
//此时要在 第一次执行定时任务的时间 加一天,以便此任务在下个时间点执行。如果不加一天,任务会立即执行。
if (date.before(new Date())) {
date = this.addDay(date, 1);
}

Timer timer = new Timer();

NFDFlightDataTimerTask task = new NFDFlightDataTimerTask();
//安排指定的任务在指定的时间开始进行重复的固定延迟执行。
timer.schedule(task,date,PERIOD_DAY);
}

// 增加或减少天数
public Date addDay(Date date, int num) {
Calendar startDT = Calendar.getInstance();
startDT.setTime(date);
startDT.add(Calendar.DAY_OF_MONTH, num);
return startDT.getTime();
}
}

创建一个监听器

public class NFDFlightDataTaskListener implements ServletContextListener {

public void contextInitialized(ServletContextEvent event) {
new TimerManager();
}

public void contextDestroyed(ServletContextEvent event) {
}

}

然后要在web.xml里面配置监听器

<listener>
<listener-class>
com.zhongren.Test.NFDFlightDataTaskListener
</listener-class>
</listener>

更多相关文章

  1. mysql 排序两个字段/列表先根据时间升序排序,时间相同再根据商家I
  2. 在H2数据库中插入时间——函数“PARSEDATETIME”未找到
  3. MySQL在保存数据时添加时间戳
  4. mysql查询一条工单时间需要10秒。优化sql语句得以解决。
  5. 如何从mysql datetime列返回转换后的时间格式?
  6. 如何将休眠时间戳映射到MySQL BIGINT?
  7. 为什么这个查询需要很长时间才能执行
  8. 在时间戳和相应的值中选择每天的最后一个条目。
  9. 如何在php中测量mysql时间,sql查询的时间和/或负载?

随机推荐

  1. 分布式作业系统 Elastic-Job-Lite 源码分
  2. 注册中心 Eureka 源码解析 —— 网络通信
  3. 消息中间件 RocketMQ 源码解析 —— 调试
  4. 分布式作业 Elastic-Job-Lite 源码分析
  5. 基于Spring Boot实现图片上传/加水印一把
  6. 轻量级 Memcached缓存代理 twemproxy实践
  7. 分布式作业系统 Elastic-Job-Lite 源码分
  8. Spring Boot 工程集成全局唯一ID生成器 V
  9. Eureka Server 开启Spring Security Basi
  10. 微信小程序入门与实战-全新版