这篇文章主要讲解了“@Scheduled不执行怎么办”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“@Scheduled不执行怎么办”吧!
@Scheduled不执行的原因
1. 今天用@Schedule做了一个定时任务
希望凌晨1点执行,代码如下
@Servicepublic class ParseJsonService { @Scheduled(cron = "0 0 1 * * ?") public void parseMongodbDataToJson() { }}
第二天来公司了,发现根本没有执行。然后开始查找问题
2. 首先遇到查到的一个解决方案
说是spring的版本的问题,我看了下我以前用的定时任务,的确spring用的是4. 于是我将spring的版本换成了4,发现还是不好使
3. 还有版本说要在spring
的配置文件中加上注解驱动
<task:annotation-driven />
并且还要加上default-lazy-init="false"属性,说是不让spring懒加载,但是发现还是不行
4. 又查到版本说要在Bean上加上@Lazy(false)
让spring对该Bean在启动的时候就加载,但是发现还是不行
终极解决方案(适合我,不一定适合你, 我用的Spring版本是3,不是4)
在spring的配置文件中加上
<task:annotation-driven />
在上述Bean上加上
@EnableScheduling
代码如下:
@Service@EnableSchedulingpublic 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"/>
@Componentpublic class CommonSchedule { //@Scheduled(cron = "0 0 1 * * ?") @Scheduled(cron = "*/5 * * * * ?") public void avg() { System.out.println("现在开始计算平均值 当前时间为"); }}
本以为就搞定了 ,发现不生效!!!
开始网上查询资料。
@EnableScheduling
也加了 不生效!@Lazy(false)
也加了 不生效!!
开始有点慌了,看了下包路径 没问题啊 ,想着用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" />
发现还是不生效!!!!!!!
这时候前端访问了一下我的接口 ,看了看log ,卧槽 system 打印了 !!!
冷静了一下
@Lazy(false) 不生效??没道理啊 然后开始翻配置文件看是不是有些bean 添加 default-lazy-init=“true” 属性了 ,也没有啊。
最后发现 :
不知道哪位奇葩 把这行给注掉了。
果断取消注释 解决问题。
感谢各位的阅读,以上就是“@Scheduled不执行怎么办”的内容了,经过本文的学习后,相信大家对@Scheduled不执行怎么办这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!