1. 程式人生 > >Spring的定時任務@Scheduled,部署後執行載入兩次

Spring的定時任務@Scheduled,部署後執行載入兩次

最近公司讓做定時抓取新聞的一個定時,一切都部署好後,發現每次都載入了兩次。配置檔案都檢查了,也沒發現問題。

1.註解的配置

	<!-- 	啟用註解定時 -->
	<task:annotation-driven scheduler="myScheduler"/>  
	<task:scheduler id="myScheduler" pool-size="10"/><!-- 	啟用註解定時 -->
	<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("快取已載入完畢!");
	}
/** * 定時取資料 * 只過濾一次,此定時的時間早於獲取新聞的時間 */ @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"/>	<Context docBase="bsny-manage-web" path="" reloadable="false" source="org.eclipse.jst.jee.server:bsny-manage-web"/>
</Host>

4.歡迎大家關注【碼農新銳】公眾號,加入我們一起來進階Java。