每刻任务,每日任务,每月1日任务
TaskExeListener.java
import java.text.Format;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.Timer;
import java.util.TimerTask;
import org.apache.log4j.Logger;
public class TaskExeListener {
private final static Logger logger = Logger.getLogger(TaskExeListener.class);
public TaskExeListener() {
logger.info("已启动...");
// 指定的任务,从指定的延迟后,开始进行重复执行。
Calendar calendar = Calendar.getInstance();
int year = calendar.get(Calendar.YEAR);
int month = calendar.get(Calendar.MONTH);
int day = calendar.get(Calendar.DAY_OF_MONTH);
Format f = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
/**
* 定制每天的8:00:00执行,若程序已超过8点启动,当天不再执行,等到明日八点再执行
* 这样保证了时间一直是8点,而不会变成程序启动时间
*/
calendar.set(year, month, day, 8, 00, 00);
Date defaultdate = calendar.getTime();// 今天8点(默认发送时间)
Date sendDate = new Date();
// 8点后开机
if (defaultdate.before(new Date())) {
// 将发送时间设为明天8点
calendar.add(Calendar.DATE, 1);
sendDate = calendar.getTime();
}
/**
* ----------------每刻任务 ----------------
* 启动后,若此时时间没过8点,等待。到了8点自动执行一次,15分钟后再执行一次,周而复始
* 启动后,若此时时间超过8点,会立刻执行一次,等到15分钟后再次执行一次,周而复始
* 到了第二天,不会再判断是否是8点,这个开始时间,只会判断一次
*/
Timer qTimer = new Timer();
TimerTask qTask = new TimerTask() {
@Override
public void run() {
long start = System.currentTimeMillis();
//do something
logger.info("每刻任务已执行!执行时间:" + f.format(start) + " 执行用时:" + (System.currentTimeMillis()-start) + "ms");
}
};
qTimer.schedule(qTask, defaultdate, 15*60*1000);// 定时每15分钟
logger.debug("每刻定时发送信息监听--已启动!");
/**
* ----------------每日任务 ----------------
* 启动后,若此时时间没过8点,等待。到了8点自动执行一次,24小时后(第二天8点)再执行一次,周而复始
* 启动后,若此时时间已经超过8点,会等到24小时后(第二天8点)再次执行一次,周而复始
*/
Timer dTimer = new Timer();
TimerTask dTask = new TimerTask() {
@Override
public void run() {
long start = System.currentTimeMillis();
//do something
logger.info("每日任务已执行!执行时间:" + f.format(start) + " 执行用时:" + (System.currentTimeMillis()-start) + "ms");
}
};
dTimer.schedule(dTask, sendDate, 24 * 60 * 60 * 1000);// 定时24小时:24 * 60 * 60 * 1000
logger.debug("每日定时发送信息监听--已启动!");
/**
* ----------------每月任务 ----------------
* 启动后,若此时时间没过8点,等待。到了8点自动执行判断是否是当前月份的1号,若是则执行一次,
* 24小时后(第二天8点)再执行一次判断(每月1号以后后的29天或30天后才会是下月1号,再执行一次),周而复始
* 启动后,若此时时间已经超过8点,24小时后(第二天8点)再执行一次判断(每月1号以后后的29天或30天后才会是下月1号,再执行一次),周而复始
*/
Timer mTimer = new Timer();
TimerTask mTask = new TimerTask() {
@Override
public void run() {
Calendar c = Calendar.getInstance();
int day = c.get(Calendar.DAY_OF_MONTH);
logger.info("月任务 判断是否为月初...");
if (day == 1) {
// 每天执行,若为每月1号才执行
long start = System.currentTimeMillis();
//do something
logger.info("月任务执行已执行!执行时间:" + f.format(start) + " 执行用时:" + (System.currentTimeMillis()-start) + "ms");
}else {
logger.info("非月初,月任务不执行!");
}
}
};
mTimer.schedule(mTask, sendDate, 24 * 60 * 60 * 1000);// 每天执行一次检查
logger.debug("每月定时发送信息监听--已启动!");
}
public static void main(String[] args) {
new TaskExeListener();
}
}log4j.properties
# Configure logging for testing: optionally with log file #log4j.rootLogger=debug,appender #log4j.rootLogger=info,appender #log4j.rootLogger=error,appender log4j.rootLogger=all,appender #输出到控制台 log4j.appender.appender=org.apache.log4j.ConsoleAppender #样式为TTCCLayout log4j.appender.appender.layout=org.apache.log4j.TTCCLayout
- 本文固定链接: https://www.coordsoft.com/post/21.html
- 转载请注明: admin 于 生活随想 - zwgu 's world 发表
求加[和谐]!https://www.2kdy.com