java timer 执行次数,java timer定时器次次执行会重复执行2次任务

探讨了在Tomcat服务器上使用Java Timer定时器时出现的任务重复执行现象,尤其是在部署到Linux服务器环境下,原本应每隔50分钟执行一次的任务却执行了两次。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

java timer定时器每次执行会重复执行2次任务

web.xml监听配置

com.numenzq.mc.service.impl.TimerListener

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.youkuaiyun.com/topics/270068464

http://bbs.youkuaiyun.com/topics/340002087

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值