关于@Scheduled不执行的原因分析

网友投稿 2230 2022-11-11

关于@Scheduled不执行的原因分析

关于@Scheduled不执行的原因分析

目录@Scheduled不执行的原因1. 今天用@jsUqjoSJsUqjochedule做了一个定时任务2. 首先遇到查到的一个解决方案3. 还有版本说要在spring4. 又查到版本说要在Bean上加上@Lazy(false)@Scheduled不生效的排查记录@Scheduled 不生效的排查记录

@Scheduled不执行的原因

1. 今天用@Schedule做了一个定时任务

希望凌晨1点执行,代码如下

@Service

public class ParseJsonService {

@Scheduled(cron = "0 0 1 * * ?")

public void parseMongodbDataToJson() {

}

}

第二天来公司了,发现根本没有执行。然后开始查找问题

2. 首先遇到查到的一个解决方案

说是spring的版本的问题,我看了下我以前用的定时任务,的确spring用的是4. 于是我将spring的版本换成了4,发现还是不好使

3. 还有版本说要在spring

的配置文件中加上注解驱动

并且还要加上default-lazy-init="false"属性,说是不让spring懒加载,但是发现还是不行

4. 又查到版本说要在Bean上加上@Lazy(false)

让sprinhttp://g对该Bean在启动的时候就加载,但是发现还是不行

终极解决方案(适合我,不一定适合你, 我用的Spring版本是3,不是4)

第一步:在spring的配置文件中加上

第二步:在上述Bean上加上

@EnableScheduling

代码如下:

@Service

@EnableScheduling

public class ParseJsonService {

@Scheduled(cron = "0 0 1 * * ?")

public void parseMongodbDataToJson() {

}

}

@Scheduled不生效的排查记录

@Scheduled 不生效的排查记录

公司之前项目要加个定时处理,觉得so easy。

@Component

public class CommonSchedule {

//@Scheduhttp://led(cron = "0 0 1 * * ?")

@Scheduled(cron = "*/5 * * * * ?")

public void avg() {

System.out.println("现在开始计算平均值 当前时间为");

}

}

本以为就搞定了 ,发现不生效!!!

开始网上查询资料。

@EnableScheduling 也加了 不生效!

@Lazy(false) 也加了 不生效!!

开始有点慌了,看了下包路径 没问题啊 ,想着用xml 配一遍

发现还是不生效!!!!!!!

这时候前端访问了一下我的接口 ,看了看log ,卧槽 system 打印了 !!!

冷静了一下

@Lazy(false) 不生效??没道理啊 然后开始翻配置文件看是不是有些bean 添加 default-lazy-init=“true” 属性了 ,也没有啊。

最后发现 :

不知道哪位奇葩 把这行给注掉了。

果断取消注释 解决问题。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:odoo 取消保存提示
下一篇:itertools实例与生成器代码
相关文章

 发表评论

暂时没有评论,来抢沙发吧~