每刻任务,每日任务,每月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 发表
《本文》有 0 条评论