首页 > Java > Java定时任务
2019
01-25

Java定时任务

每刻任务,每日任务,每月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


本文》有 0 条评论

留下一个回复