如何利用crond实现秒级定时任务?

简介:

1.问题引出:crond实现定时任务的思路

    crond服务默认情况每分钟检查系统中是否有需要执行的定时任务,如果有,就会根据事先定义好的规则来执行这个定时任务,而crond配置的书写语法中:“* * * * * command”,最低的时间单位是分钟,所以说,一个crond定时任务最多只能执行分钟级的定时任务,这是显然的!但事实情况是,利用crond也是可以实现秒级的定时任务的,既然一个定时任务真的就只能实现分钟级的定时任务,那我几个定时任务同时实现一个功能,是否有可能达到秒级???


2.实际案例:利用crond实现每二十秒的定时任务

请先看下面的定时任务书写:

1
2
3
* * * * * /bin/echo  "Hello"  >> /server/scripts/hello.log
* * * * * sleep  20 ;/bin/echo  "Hello"  >> /server/scripts/hello.log
* * * * * sleep  40 ;/bin/echo  "Hello"  >> /server/scripts/hello.log

看了上面的三条语句,懂思路的人相信已经知道如何利用crond来实现秒级的定时任务。上面这三条语句大致相同,无非就是想做下面的一件事:

1
/bin/echo  "Hello"  >> /server/scripts/hello.log

即实际上,三条语句(其实准确点说是三个定时任务)的最终目的是一样的,至于为何它就能实现每20秒一次的定时任务,请看下面的分析:


a.crond服务每分钟检查系统中的定时任务

b.计时开始,三个定时任务同时执行:

执行第一个定时任务时,便输出数据到hello.log;

执行第二个定时任务时,先休息20秒(sleep 20),再准备该定时任务下一个命令的执行;

执行第三个定时任务时,先休息40秒(sleep 40),再准备该定时任务下一个命令的执行;

b.过了20秒后,第二个定时任务便执行第二个命令,也是输出数据到hello.log;此时第三个定时任务还有20秒就执行第二个命令(已经sleep了20,还要再sleep20)

c.再过20秒,第三个定时任务便执行第二个命令,也是输出数据到hello.log;

d.又过20秒,此时一分钟已经过去了,crond服务又开始检查系统中的定时任务

……

以此类推,当我们tail -f hello.log的方法追踪hello.log中的数据变化时,可以看到每20秒就有一个hello输出,即我们上面的方法就实现了每20秒的定时任务了。


3.如何用上面方法实现每秒级的定时任务?

实际可以发现,上面的方法只是用变通的思路来实现秒级的定时任务,即多条crond语句+sleep,那如果想要实现每秒级的定时任务,想一下,按照这种思路去做,那是不是相当于下面这样:

1
2
3
4
5
6
* * * * * command
* * * * * sleep  1 ;command
* * * * * sleep  2 ;command
* * * * * sleep  3 ;command
……
* * * * * sleep  59 ;command

实现一个功能就要写60条crond语句!

所以没有人会这样去干吧,这样的效率也真是太低了!所以,虽然是可以实现每秒级的定时任务,但由于效率实在太低,也太麻烦了,如果真有这样的需要,就得用其他方法替代了,比如写shell脚本程序、借助第三方软件实现等。


4.可以实现每几十秒的定时任务

因此,用上面介绍的方法,其实要实现几十秒每次的定时任务,也是比较简单的,如果没有太严格的要求,也可以考虑考虑的。

相关文章
|
存储 负载均衡 监控
分布式定时任务,你了解多少?基于Quartz实现分布式定时任务解决方案!
定时任务系统在应用平台中的重要性不言而喻,特别是互联网电商、金融等行业更是离不开定时任务。在任务数量不多、执行频率不高时,单台服务器完全能够满足。但是随着业务逐渐增加,定时任务系统必须具备高可用和水平扩展的能力,单台服务器已经不能满足需求。因此需要把定时任务系统部署到集群中,实现分布式定时任务系统集群。
4651 1
分布式定时任务,你了解多少?基于Quartz实现分布式定时任务解决方案!
|
3月前
|
存储 运维 监控
运维.Linux下执行定时任务(中:Cron的常用替代方案)
本文是关于Linux下执行定时任务系列的第二部分,主要探讨除了Cron之外的常用替代方案。介绍了Systemd Timers、Anacron及at命令三种工具,它们分别适用于不同场景下的定时任务需求。文章详细分析了每种工具的特点、工作原理、基本使用方法及其高级功能,并对比了它们各自的优缺点,帮助读者根据实际情况选择最适合的定时任务解决方案。此外,还提供了指向具体实例和进一步阅读材料的链接。
115 4
运维.Linux下执行定时任务(中:Cron的常用替代方案)
|
3月前
|
存储 消息中间件 移动开发
还在用crontab? 分布式定时任务了解一下
还在用crontab? 分布式定时任务了解一下
|
4月前
|
监控 Java 调度
若依修改定时任务,定时任务在系统监控的定时任务当中,宕机情况都不会去管,涉及到定时任务
若依修改定时任务,定时任务在系统监控的定时任务当中,宕机情况都不会去管,涉及到定时任务
|
6月前
|
弹性计算 运维 Shell
基于Cron的自动化任务调度
【4月更文挑战第30天】
30 0
|
6月前
|
运维 Linux 应用服务中间件
Linux 定时任务crontab实现秒级定时以及@reboot的一些问题
Linux 定时任务crontab实现秒级定时以及@reboot的一些问题
831 0
|
缓存 Linux 调度
分布式定时任务
分布式定时任务
139 0
分布式定时任务
|
消息中间件 算法 Java
定时任务实现方案总结
定时任务实现方案总结
96 0
定时任务实现方案总结
|
关系型数据库 MySQL 调度
定时任务优化
简单描述一下定时任务的优化
135 0
|
负载均衡 Java 数据挖掘
定时任务实现的几种方式
定时任务实现的几种方式
283 1