首页 > 编程知识 正文

crontab定时任务配置每分钟执行,定时执行脚本

时间:2023-05-06 06:26:03 阅读:47365 作者:2678

前言

除了web APP应用程序和SOA服务之外,实际的项目开发还有一个不可缺少的部分。 那是定时任务日程。 可以说计时器任务的场景非常广泛。 例如,在一些视频网站上,购买会员后,每天都会向会员发送成长值,每月向会员发送电影票,例如在保证最终一致性的情况下,经常利用定时任务日程进行一些比对工作,例如需要在几个定时生成的报告例如,需要定期清理数据的任务。 本博客介绍系统介绍时间表,包括Timer、ScheduledExecutorService、开源工具包Quartz、Spring和Quartz的组合。

JDK本机时间工具: Timer时间任务调度:根据指定时间、指定时间间隔和指定执行次数自动执行的任务。

Timer位于java.util包下,其中只包含一个后台线程,并包含用于调度多个业务任务“TimeTask”的调度。

schedule的四种用法和scheduleAtFixedRate的两种用法

Timer的核心方法参数说明:

任务:要执行的任务需要扩展时间任务复盖run ()

time/firstTime :第一次执行任务的时间

period :周期性执行任务的时间间隔。 毫秒单位

延迟:执行任务任务的延迟时间。 以毫秒为单位

很明显,根据上述说明,我们可以

推迟多长时间执行任务; 指定时间延迟执行一次任务的时间,指定定期执行任务的时间,定期执行任务

思考1 )如果time/firstTime指定的时间早于当前时间,会发生什么? 当时间大于或等于time/firstTime时,执行任务! 也就是说,如果time/firstTime指定的时间早于当前时间,则立即执行。

思考2:schedule和scheduleAtFixedRate有什么区别? scheduleAtFixedRate :每个运行时间从上一次任务开始向后移动一个周期间隔。 也就是说,下次运行的时间相对于上次任务的开始时间,因此运行时间不会延迟,但存在任务同时运行的问题。

schedule (各执行时间自上次任务结束后前进1个period间隔。 也就是说,下次的执行时间相对于上次任务结束的时间点,因此执行时间不断延迟。

思考3 )运行task发生异常时,会影响其他task的日程吗? 当TimeTask抛出运行时执行时,Timer将停止执行所有任务!

思考4:Timer的一些缺陷? 如上所述,由于Timer后面有单线程,因此Timer具有管理并发任务的缺点。 所有任务都在同一线程上调度,所有任务都是串行执行的。 也就是说,同一时间只能执行一个任务,上一个任务的延迟和异常会影响后续任务。

其次,Timer的一些调度方案不能适应实际项目中任务调度的复杂性。

简单的Demo实例

Timer Demo

执行结果

Timer的其他值得注意的方法cancel () :退出Timer计时器并放弃所有当前计划的任务(TimeTask也是cancel ) ),但要退出的是TimeTask

purge () :从计时器的任务队列中删除已取消的任务,并返回个数

JDK线程池对调度任务调度的支持:由于ScheduledExecutorServicetimer问题,在JDK5之后基于线程池调度调度任务: ScheduledExecutorServicetimer

设计理念:所有计划的任务都由线程池中的一个线程执行,因此任务可以同时执行,而不会相互影响。

让我们直接来看一个例子:

基于线程池的计划任务调度

执行结果:

结果

定时任务哥哥: Quartz虽然ScheduledExecutorService在Timer上进行了线程池的改进,但仍然不能满足复杂的定时任务调度场景。 因此,OpenSymphony提供了一个名为Quartz的强大的开源任务调度框架。 Quartz是纯Java实现,而且作为Spring的默认调度框架,具有Quartz强大的调度功能、灵活的使用方法和分布式集群能力,所以Quartz出马后,所有定时的Java

Quartz体系结构

Quartz架构

让我们先来看看Demo :

业务作业

Quartz说明:

1、从代码上看,有XxxBuilder、XxxFactory,表明Quartz用于Builder、f

actory模式,还有非常易懂的链式编程风格。

2、Quartz有3个核心概念:调度器(Scheduler)、任务(Job&JobDetail)、触发器(Trigger)。(一个任务可以被多个触发器触发,一个触发器只能触发一个任务)

3、注意当Scheduler调度Job时,实际上会通过反射newInstance一个新的Job实例(待调度完毕后销毁掉),同时会把JobExecutionContext传递给Job的execute方法,Job实例通过JobExecutionContext访问到Quartz运行时的环境以及Job本身的明细数据。

4、JobDataMap可以装载任何可以序列化的数据,存取很方便。需要注意的是JobDetail和Trigger都可以各自关联上JobDataMap。JobDataMap除了可以通过上述代码获取外,还可以在YourJob实现类中,添加相应setter方法获取。

5、Trigger用来告诉Quartz调度程序什么时候执行,常用的触发器有2种:SimpleTrigger(类似于Timer)、CronTrigger(类似于Linux的Crontab)。

6、实际上,Quartz在进行调度器初始化的时候,会加载quartz.properties文件进行一些属性的设置,比如Quartz后台线程池的属性(threadCount)、作业存储设置等。它会先从工程中找,如果找不到那么就是用quartz.jar中的默认的quartz.properties文件。

7、Quartz存在监听器的概念,比如任务执行前后、任务的添加等,可以方便实现任务的监控。

CronTrigger示例

CronTrigger

Cron表达式的写法

特殊符号说明

cron表达式这里给出一些常用的示例:

0 15 10 * * ? *每天10点15分触发

0 15 10 * * ? 20172017年每天10点15分触发

0 * 14 * * ?每天下午的 2点到2点59分每分触发

0 0/5 14 * * ?每天下午的 2点到2点59分(整点开始,每隔5分触发)

0 0/5 14,18 * * ?每天下午的 2点到2点59分、18点到18点59分(整点开始,每隔5分触发)

0 0-5 14 * * ?每天下午的 2点到2点05分每分触发

0 15 10 ? * 6L每月最后一周的星期五的10点15分触发

0 15 10 ? * 6#3每月的第三周的星期五开始触发

我们可以通过一些Cron在线工具非常方便的生成,比如http://www.pppet.net/等。

Spring和Quartz的整合实际上,Quartz和Spring结合是很方便的,无非就是进行一些配置。大概基于2种方式:

第一,普通的类,普通的方法,直接在配置中指定(MethodInvokingJobDetailFactoryBean)。

第二,需要继承QuartzJobBean,复写指定方法(executeInternal)即可。

然后,就是一些触发器、调度器的配置了,这里不再展开介绍了,只要弄懂了原生的Quartz的使用,那么和Spring的结合使用就会很简单。

好了,到这里,定时任务调度就结束了,周末愉快!

2017-09-24 dxz

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。