2

我有一个 php 脚本,一旦将一些数据插入 SQL 数据库,它就会设置一个 cron 作业:

<?
$output = shell_exec('crontab -l');
file_put_contents('/tmp/crontab.txt', $output.'* * * * * /usr/local/bin/php /home/dldl1330/public_html/new/mailchimp.php'.PHP_EOL);
echo exec('crontab /tmp/crontab.txt');
?>

此 cron 作业执行另一个脚本,该脚本将 SQL DB 与 mailchimp 同步。在这个 mailchimp php 脚本中,它删除了 cron 选项卡:

echo exec('crontab -r');

一旦发生这种情况,我会丢失我的 cron 选项卡中的所有作业(并且它会删除在每个 cron 作业之后通过电子邮件发送的电子邮件),我怎样才能做到这一点,以便上面的行只删除/home/dldl1330/public_html/new/mailchimp.phpcron 作业?

4

1 回答 1

7

我使用了上述建议并提出了一个解决方案,我不确定它的效率或正确性....欢迎发表评论。

注意: //Find string 部分仅用于我的调试/学习目的

<?php
//get contents of cron tab
$output = shell_exec('crontab -l');
echo "<pre>$output</pre>";

//Find string
$cronjob = ('* * * * * /usr/local/bin/php /home/dldl1330/public_html/new/mailchimp.php');
if (strstr($output, $cronjob)) {
   echo 'found';
} else {
   echo 'not found';
}

//Copy cron tab and remove string
$newcron = str_replace($cronjob,"",$output);
echo "<pre>$newcron</pre>";

file_put_contents('/tmp/crontab.txt', $newcron.PHP_EOL);
echo exec('crontab /tmp/crontab.txt');

?>
于 2013-04-05T11:34:21.410 回答