`
hbxflihua
  • 浏览: 660806 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

延时调度任务demo

    博客分类:
  • java
阅读更多

 

 

1、定制调度任务:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.rd.ifaes.core.project.domain.Project;

/**
 * 项目缓存延时调度任务
 * @author lh
 * @version 3.0
 * @since 2016-8-26
 *
 */
public class ProjectCacheDelaySchedule implements Runnable {
	
	private final static Logger LOGGER = LoggerFactory.getLogger(ProjectCacheDelaySchedule.class);
	
	//项目信息
	private Project project;
	//延时时间(单位:秒)
	private long delay;
	
	public ProjectCacheDelaySchedule(Project project) {
		super();
		this.project = project;
		delay = project.getShowTime().getTime() - System.currentTimeMillis();
		delay = (delay > 0) ? delay / 1000 : 0;
	}
	
	/**
	 * 取得延时时间
	 * @return
	 */
	public long getDelay() {
		return delay;
	}

	/**
	 * project添加到缓存
	 */
	@Override
	public void run() {
		LOGGER.info("project to cache, projectNo="+project.getProjectNo());
		ProjectCache.setProject(project);
	}
	
}

 

 

2、加入调度任务:

	private static ScheduledExecutorService projectSaleService = Executors.newScheduledThreadPool(1);
	/**
	 * 项目上架 ( 仅供后台产品或借贷上架用 )
	 * @param project
	 */
	public static void projectSale(Project project){
		ProjectCacheDelaySchedule executor = new ProjectCacheDelaySchedule(project);
		projectSaleService.schedule(executor, executor.getDelay(), TimeUnit.SECONDS);
	}

 The end!

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics