關于@Scheduled不執(zhí)行的原因分析
@Scheduled不執(zhí)行的原因
1. 今天用@Schedule做了一個定時任務
希望凌晨1點執(zhí)行,代碼如下
@Service public class ParseJsonService { @Scheduled(cron = "0 0 1 * * ?") public void parseMongodbDataToJson() { } }
第二天來公司了,發(fā)現根本沒有執(zhí)行。然后開始查找問題
2. 首先遇到查到的一個解決方案
說是spring的版本的問題,我看了下我以前用的定時任務,的確spring用的是4. 于是我將spring的版本換成了4,發(fā)現還是不好使
3. 還有版本說要在spring
的配置文件中加上注解驅動
<task:annotation-driven />
并且還要加上default-lazy-init="false"屬性,說是不讓spring懶加載,但是發(fā)現還是不行
4. 又查到版本說要在Bean上加上@Lazy(false)
讓spring對該Bean在啟動的時候就加載,但是發(fā)現還是不行
終極解決方案(適合我,不一定適合你, 我用的Spring版本是3,不是4)
第一步:在spring的配置文件中加上
<task:annotation-driven />
第二步:在上述Bean上加上
@EnableScheduling
代碼如下:
@Service @EnableScheduling public class ParseJsonService { @Scheduled(cron = "0 0 1 * * ?") public void parseMongodbDataToJson() { } }
@Scheduled不生效的排查記錄
@Scheduled 不生效的排查記錄
公司之前項目要加個定時處理,覺得so easy。
<!-- 開啟定時任務 --> <task:annotation-driven /> <!-- 開啟注解 --> <context:annotation-config /> <!-- 指定相關的包路徑 --> <context:component-scan base-package="com.ffrj.schedule"/>
@Component public class CommonSchedule { //@Scheduled(cron = "0 0 1 * * ?") @Scheduled(cron = "*/5 * * * * ?") public void avg() { System.out.println("現在開始計算平均值 當前時間為"); } }
本以為就搞定了 ,發(fā)現不生效!?。?/p>
開始網上查詢資料。
@EnableScheduling
也加了 不生效!@Lazy(false)
也加了 不生效?。?/li>
開始有點慌了,看了下包路徑 沒問題啊 ,想著用xml 配一遍
<task:annotation-driven /> <bean id="myTaskXml" class="com.ffrj.schedule.CommonSchedule "></bean> <task:scheduled-tasks> <task:scheduled ref="myTaskXml" method="show" cron="*/5 * * * * ?" /> </task:scheduled-tasks> <context:component-scan base-package="com.ffrj.schedule" />
發(fā)現還是不生效?。。。。。。?/p>
這時候前端訪問了一下我的接口 ,看了看log ,臥槽 system 打印了 !!!
冷靜了一下
@Lazy(false) 不生效??沒道理啊 然后開始翻配置文件看是不是有些bean 添加 default-lazy-init=“true” 屬性了 ,也沒有啊。
最后發(fā)現 :
不知道哪位奇葩 把這行給注掉了。
果斷取消注釋 解決問題。
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Java靜態(tài)方法不能調用非靜態(tài)成員的原因分析
在Java中,靜態(tài)方法是屬于類的方法,而不是屬于對象的方法,它可以通過類名直接調用,無需創(chuàng)建對象實例,非靜態(tài)成員指的是類的實例變量和實例方法,它們需要通過對象實例才能訪問和調用,本文小編將和大家一起探討Java靜態(tài)方法為什么不能調用非靜態(tài)成員2023-10-10Maven中dependencyManagement管理項目依賴項
在開發(fā)?Java?項目時,管理和協調依賴項的版本號是一項重要而繁瑣的任務,本文主要介紹了Maven中dependencyManagement管理項目依賴項,具有一定的參考價值,感興趣的可以了解一下2024-01-01