您的位置 首页 > 德语词汇

scheduled是什么意思 系列之定时任务

各位老铁们好,相信很多人对scheduled是什么意思都不是特别的了解,因此呢,今天就来为大家分享下关于scheduled是什么意思以及系列之定时任务的问题知识,还望可以帮助大家,解决大家的一些困惑,下面一起来看看吧!

1、生有涯,学海无涯

scheduled是什么意思 系列之定时任务

2、Spring的定时任务想必大家多多少少都用过,经过Spring团队的封装,大家使用起来非常的方便和简洁,那关于定时任务的真正使用还有哪些你不知道的事呢?下面我们一起来看一下吧。

3、在使用Scheduled注解前,我们先看下,官方给出了使用条件

4、Anannotationthatmarksamethodtobescheduled.Exactlyoneofthecron(),fixedDelay(),orfixedRate()attributesmustbespecified.

5、Theannotatedmethodmustexpectnoarguments.Itwilltypicallyhaveavoidreturntype;ifnot,thereturnedvaluewillbeignoredwhencalledthroughthescheduler.

6、Processingof@ScheduledannotationsisperformedbyregisteringaScheduledAnnotationBeanPostProcessor.Thiscanbedonemanuallyor,moreconveniently,throughthe<task:annotation-driven/>elementor@EnableSchedulingannotation.

7、意思是说,在使用Scheduled注解的时候,必须设置cron(),fixedDelay(),fixedRate()三个中的一个属性。该注解使用的方法不期望接收任何参数,并且要使用void返回类型,即使设置了返回值,也会在回调的时候被忽略。第三句是说,我们在使用Scheduled注解的时候需要注册ScheduledAnnotationBeanPostProcessor,可以通过手动,或者配置<task:annotation-driven/>或者在Springboot项目中,直接在启动类上添加@EnableScheduling注解都可以。总结一下就是

8、在平时使用的时候我们基本上只要加一个注解,然后再配置上相应的cron参数就可以了。如下所示:

9、这几种的配置方式还是比较简单的,可以根据自己的场景以及需求来设置。可以说都还是比较常用的。

10、这里结合自身项目,跟大家介绍几个在使用的过程中容易遇到的一些问题。

11、Spring的任务调用默认使用的是单线程模式,这个如果大家没有在生产上真正遇到过可能不会发现有问题,毕竟本地和测试环境数据少,不容易出现,但是在真正复杂的生产环境中,还是要十分注意的。

12、由于Spring的默认实现是单线程,所以在生产的时候如果任务一旦多了,而且耗时长了,就会出现很多意想不到的情况,比如会发现某个任务不执行,或者没有按照指定的时间运行。这种情况往往是很恐怖的,如果说对实时性要求不高的话,影响不大,如果实时性要求很高的话,那绝对不能容忍。

13、这个时候我们需要自定义taskScheduler,通过如下方式

14、importorg.springframework.beans.factory.annotation.Value;\nimportorg.springframework.context.annotation.Configuration;\nimportorg.springframework.scheduling.annotation.SchedulingConfigurer;\nimportorg.springframework.scheduling.config.ScheduledTaskRegistrar;\n\n/**\n*<br>\n*<b>功能:</b><br>\n*<b>作者:</b>@author子悠<br>\n*<b>日期:</b>2019-08-2217:51<br>\n*<b>详细说明:</b>无<br>\n*/\n@Configuration\npublicclassScheduledThreadPoolConfigimplementsSchedulingConfigurer{\n\n@Value("${thread.pool.corePoolSize:10}")\nprivateintcorePoolSize;\n\n@Override\npublicvoidconfigureTasks(ScheduledTaskRegistrarscheduledTaskRegistrar){\nscheduledTaskRegistrar.setScheduler(Executors.newScheduledThreadPool(corePoolSize));\n}\n}\n\n

通过实现SchedulingConfigurer接口中的configureTasks方法,来创建一个ScheduledTask并注入到ScheduledTaskRegistrar中。

15、这样就可以自定义线程数,从而避免上述问题的存在。

16、另外还有一个问题就是如果一个模块定时任务很多,最好可以封装为一个独立的任务调度模块,对于负责场景的任务调度可以采用一些开源的调度框架,比如XXL-JOB,Azkaban。

17、如果只是一些简单的定时任务,不需要引入开源框架的时候,那么自己开发后在部署的时候需要注意多实例会重复运行的情况,意思是说一个定时任务模块,如果部署了两个实例就会导致任务重复执行。这种时候只能采用单实例部署,单实例部署的时候需要加守护进程和程序监控,避免程序出问题。

18、如果是在需要高可用,可以自己开发调度模块或者采用开源的框架实现。大部分场景XXL-JOB应该都可以满足。

19、今天给大家介绍了Spring框架中的Scheduled组件的简单使用,以及在使用过程中注意的一些事项,希望对大家有帮助。

OK,关于scheduled是什么意思和系列之定时任务的内容到此结束了,希望对大家有所帮助。

本站涵盖的内容、图片、视频等数据,部分未能与原作者取得联系。若涉及版权问题,请及时通知我们并提供相关证明材料,我们将及时予以删除!谢谢大家的理解与支持!

Copyright © 2023