crontab 实现每 N 秒执行的定时任务的方法

2023年01月01日 2351点热度 0人点赞 0条评论

crontab 命令最小的执行时间是一分钟,如需要在小于一分钟内重复执行,有两个方法实现。

1.使用延时来实现每N秒执行

此方法原理是通过延时方法 sleep N 来实现每N秒执行,首先创建一个php脚本test.php,本例test.php放在home目录下,功能是把当前时间写入/home/test.log

crontab -e

输入以下语句保存退出:

* * * * * php /home/test.php
* * * * * sleep 10; php /home/test.php
* * * * * sleep 20; php /home/test.php
* * * * * sleep 30; php /home/test.php
* * * * * sleep 40; php /home/test.php
* * * * * sleep 50; php /home/test.php

使用 tail -f 查看执行情况,可以见到log每10秒被写入一条记录:

[root@web data]# tail -f /home/test.log
2023-01-01 23:47:01
2023-01-01 23:47:11
2023-01-01 23:47:21
2023-01-01 23:47:31
2023-01-01 23:47:41
2023-01-01 23:47:51
2023-01-01 23:48:01

60必须能整除间隔的秒数,如果间隔的秒数太少,例如2秒执行一次,这样就需要在crontab 加入60/2=30条语句,这样使用起来很麻烦,下面介绍的第二种方法

2.编写shell脚本实现

此方法原理是在脚本中使用for语句指定秒数执行,创建脚本文件 crontab.sh 放在home目录下,并增加执行权限:

#!/bin/bash
step=2 #间隔的秒数,不能大于60
for (( i = 0; i < 60; i=(i+step) )); do
    $(php '/home/test.php')
    sleep $step
done
exit 0
chmod +x /home/crontab.sh

crontab -e 输入以下语句后保存退出:

# m h dom mon dow command
* * * * * /home/crontab.sh

使用 tail -f 查看执行情况,可以发现run.log每2秒被写入一条记录。

路灯

这个人很懒,什么都没留下

文章评论