Spring的定时任务@Scheduled,部署后执行加载两次

最近公司让做定时抓取新闻的一个定时,一切都部署好后,发现每次都加载了两次。配置文件都检查了,也没发现问题。

1.注解的配置

 

	<!-- 	启用注解定时 -->
	<task:annotation-driven scheduler="myScheduler"/>  
	<task:scheduler id="myScheduler" pool-size="10"/>

2. 定时的代码

 

	/**
	 * 定时取数据
	 * 只过滤一次,此定时的时间早于获取新闻的时间
	 */
	@Scheduled(cron = "0 55 5,12,19 * * ?")
	public void task() {
		List<String> url = newsService.queryAllNewsUrl();
		for (String str : url) {
			if (StringUtils.isNotEmpty(str)) {
				CachePool.getInstance().putCacheItem(str, System.currentTimeMillis());
			}
		}
		int size = CachePool.getInstance().getSize();
		logger.debug("缓存数量为:"+size);
		logger.debug("缓存已加载完毕!");
	}

3.查了些资料,有的说是在配置文件中,DispatcherServlet配置加载了两次,但是我的不是这个问题。

 

最后的问题是在tomcat里,我的项目是在webapps里,而在conf下的server.xml中的<Host appBase="webapps"。。>

appBase也是指定的是webapps。所以加载了两次。我解决的方法是把项目放到另一个文件夹(新建个文件夹)下wtpwebapps就OK了!

就是把appBase='webapps',改成appBase="wtpwebapps"

 

<Host appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="true">
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"         pattern="%h %l %u %t "%r" %s %b" prefix="localhost_access_log" suffix=".txt"/>
	<Context docBase="bsny-manage-web" path="" reloadable="false" source="org.eclipse.jst.jee.server:bsny-manage-web"/>
</Host>

4.欢迎大家关注【码农新锐】公众号,加入我们一起来进阶Java。

                                                            

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值