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语句实现循环指定秒数执行。

浙公网安备 33010602011771号