ubuntu crontab 实现每秒运行

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

创建一个php做执行动作,把时间写入log

<?php
file_put_contents('/home/fdipzone/php/crontab/run.log', date('Y-m-d H:i:s')."\r\n", FILE_APPEND);
?>

crontab -e 输入以下语句,然后wq保持退出

* * * * * php /home/fdipzone/php/crontab/tolog.php
* * * * * sleep 10; php /home/fdipzone/php/crontab/tolog.php
* * * * * sleep 20; php /home/fdipzone/php/crontab/tolog.php
* * * * * sleep 30; php /home/fdipzone/php/crontab/tolog.php
* * * * * sleep 40; php /home/fdipzone/php/crontab/tolog.php
* * * * * sleep 50; php /home/fdipzone/php/crontab/tolog.php

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

fdipzone@ubuntu:~$ tail -f /home/fdipzone/php/crontab/run.log
2014-03-31 21:47:01
2014-03-31 21:47:11
2014-03-31 21:47:21
2014-03-31 21:47:31
2014-03-31 21:47:41
2014-03-31 21:47:51
2014-03-31 21:48:01

原理:通过延时方法 seleep N 来实现N秒执行

2.编写shell脚本实现

crontab.sh

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

crontab -e 输入以下语句 , 然后:wq 保存退出。

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

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

fdipzone@ubuntu:~/php/crontab$ tail -f run.log
2014-03-31 22:23:01
2014-03-31 22:23:03
2014-03-31 22:23:06
2014-03-31 22:23:08
2014-03-31 22:23:10
2014-03-31 22:23:12
2014-03-31 22:23:14
2014-03-31 22:23:16
2014-03-31 22:23:18
2014-03-31 22:23:20
2014-03-31 22:23:22
2014-03-31 22:23:25

 

原理:在sh使用for语句实现循环指定秒数执行。

 

posted @ 2018-08-06 18:45  谁懂烟花忧伤  阅读(1031)  评论(0)    收藏  举报