下面的方法虽然可以学到一些东西,但是,更优的方法应该是:http://mengkang.net/285.html
首先得搞明白怎么通过php获取linux的root权限,因为要访问/var/spool/cron目录必须有root权限。
error_reporting(E_ALL);
$data = "* * * * * curl 'http://quankr2.com/index.php?g=CollectArticle&m=Collect&a=test'\n";
file_put_contents('/mnt/hgfs/code/root', $data);
$handle = popen('/usr/bin/sudo cp /mnt/hgfs/code/root /var/spool/cron/root','r');
pclose($handle);
在访问我上面这个脚本前后cat /var/spool/cron/root
这样说明已经修改成功。那么计划任务到底是否已经正确的加入了计划呢?可以通过crontab -l查看,但是我还是不确信,所以我在http://quankr2.com/index.php?g=CollectArticle&m=Collect&a=test这个页面做了一个数据库写入操作,所以通过查看数据库的变化来看该计划任务是否有成功执行!
测试发现,OK,数据每一分钟就有一条数据进来。后面要做就是业务逻辑的拼装了。
下面是我在Thinkphp框架下面做一个定时采集的函数,在采集源有增加或者采集源的技术任务时间有修改的情况下,就调用这个函数。
/**
* 更新计划任务
* @author Zhoumengkang
*/
function update_crontab(){
$res = M('collect_source')->field('id , crontab')->order('id asc')->select();
//拼装crontab内容
$crontab = "";
foreach($res as $v){
if(intval($v['crontab']) < 24 ){
$crontab .="0 */".intval($v['crontab'])." * * * curl 'http://".$_SERVER['HTTP_HOST']."/index.php?g=CollectArticle&m=Source&a=doCollect&id=".$v['id']."'\n";
}else{
$crontab .="0 21 */".(intval($v['crontab'])/24)." * * curl 'http://".$_SERVER['HTTP_HOST']."/index.php?g=CollectArticle&m=Source&a=doCollect&id=".$v['id']."'\n";
}
}
//网站根目录保存一份,复制一份到root的定时计划里面
if((!file_exists('crontab')) || (file_get_contents('crontab') != $crontab)){
file_put_contents('crontab',$crontab);
$handle = popen('/usr/bin/sudo cp crontab /var/spool/cron/root','r');
pclose($handle);
}
}