前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[日常] crontab的秒执行和串行化和多进程实现

[日常] crontab的秒执行和串行化和多进程实现

作者头像
唯一Chat
发布2019-09-10 13:00:06
9610
发布2019-09-10 13:00:06
举报

1. crontab的最低运行频率是,按照每分钟执行一次,通过在脚本中简单实现按秒级别运行

比如这条cron规则 , 每分钟执行一次脚本

* * * * * php /var/www/html/test/cron.php

cron.php

$i=0;
while(1){
        $i++;
        if($i>60) break;
        $pid=getmypid();
        //查询队列等任务
        file_put_contents("/tmp/cron_test","{$pid}=={$i}\n",FILE_APPEND);
        sleep(1);
}

不停顿,每秒执行一次,前面的数字是当前的进程id,可以看到进程更换了

2. 两个进程同时每秒执行,只需要改下数字60改成120

<?php
$i=0;
while(1){
        $i++;
        if($i>120) break;
        $pid=getmypid();
        //查询队列等任务
        file_put_contents("/tmp/cron_test","{$pid}=={$i}\n",FILE_APPEND);
        sleep(1);
}

3.处理crontab冲突 , 同一时间只允许一个任务执行 , 使用flock文件锁

如果一个任务超过了一分钟没执行完 , 下个任务开启时会检测文件是否已经被加了锁 , 如果加锁失败就不执行脚本了

默认使用阻塞模式,就是其他进程会一直等待这个文件释放锁,释放后就立即执行

* * * * * flock -xn /tmp/mycron.lock -c 'php /var/www/html/test/cron.php'

将命令作为 flock 的 -c 选项的参数。flock 命令中,-x 表示对文件加上排他锁,-c 选项指明加锁成功后要执行的命令。

模拟脚本超时

<?php
$i=0;
while(1){
        $i++;
        //模拟进程耗时长
        if($i>rand(60,130)) break;
        $pid=getmypid();
        //查询队列等任务
        file_put_contents("/tmp/cron_test","{$pid}=={$i}\n",FILE_APPEND);
        sleep(1);
}

下面的截图可以看到 , 第二个进程执行到了flock命令 , 但是没有执行到php脚本 , 阻塞在那里了.

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-03-09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档