日期:2014-05-20  浏览次数:20862 次

java timer定时器每次执行会重复执行2次任务
web.xml监听配置

<!-- 定时监听 -->
<listener>
   <listener-class>com.numenzq.mc.service.impl.TimerListener</listener-class>
</listener>


TimerListener类

public class TimerListener implements ServletContextListener {
private Timer timer;
private TimerTaskSelf task;
/**
 * @see 销毁
 */
@Override
public void contextDestroyed(ServletContextEvent arg0) {
   timer.cancel();
}

/**
 * @see 创建
 */
@Override
public void contextInitialized(ServletContextEvent event) {
   timer = new java.util.Timer(true);
   task = new TimerTaskSelf(event.getServletContext());
   //执行任务指定间隔
   timer.scheduleAtFixedRate(task, 0, 1000*60*50);  
}
}


自定义任务类

package com.numenzq.mc.service.impl;

import java.util.Calendar;
import java.util.TimerTask;

import javax.servlet.ServletContext;

import org.apache.log4j.Logger;

public class TimerTaskSelf extends TimerTask {
private ServletContext context; 
    public TimerTaskSelf(ServletContext context){
     this.context = context; 
    } 
    @Override
    public void run() {
System.out.println(DateUtils.format(DateUtils.currentDate(),"yyyy-MM-dd HH:mm:ss") + " web监听结合定时器应用每次执行2次的问题...");
    }
}


本地tomcat-7.0.12启动, 定时器执行没问题。 
部署到服务器,linux,启动tomcat后,每次执行的时候会重复2次执行任务.
(间隔50分钟执行一次,可每到50分钟就会打印2条信息.)
望高手,帮忙找下原因. 坐等.. 


------解决方案--------------------
先在contextInitialized里打印一下看看你的listern进去了几次
------解决方案--------------------
搜索这样的问题,发现有的和虚拟目录有关,楼主这个不知道有没有配置虚拟目录?
http://bbs.csdn.net/topics/270068464
http://bbs.csdn.net/topics/340002087