其实很简单的,在做开发的过程中可能会遇到一些情况需要定时得去跑一些程序,这时呢我们就可以用到crontab这个定时器来帮助我们完成这些任务。
首先需要具体执行的PHP程序,分为两种情况:
1、单独的PHP文件(test.php)
<?php
$link = mysqli_connect("localhost","root","123456","test") or die("Error " . mysqli_error($link)); //连接,test为数据库的名称
$query = "SELECT name FROM userInfo" or die("Error in the consult.." . mysqli_error($link));//查询
$result = mysqli_query($link, $query);//查询的结果
while($row = mysqli_fetch_array($result)) {
echo $row["name"] . "<br>";
}
?>
这里是一个mysqli链接,链接数据库、查询结果并进行输出,然后我们写一个shell脚本来执行这个php程序(test.sh)
#!/bin/bash
php /Applications/MAMP/htdocs/localhosttest/test.php
注:执行此脚本时要把php加入环境变量
2、框架内的某个方法(以TP为例)
比如我们要执行index.php入口文件对应的模块下的test控制器,下面的cron方法(源码我就不写了,毕竟每个人对应的场景不一样),话不多说,直接上shell脚本(test.sh)
#!/bin/bash
url="http://test.com/index.php/test/cron"
groupfrom=(yx wz fz)
#for i in {1..12}
#do
#/usr/bin/curl $url"?year=2017-"$i"&groupfrom=fz"
#echo $url"?year=2017-"$i
#for f in ${groupfrom[@]}
#do
#/usr/bin/curl $url"?year=2017-"$i"&groupfrom="$f
#done
#done
#cur_date=`date +%Y-%m-%d`
years=(2017 2018)
for y in ${years[@]}
do
for m in {01..12}
do
/usr/bin/curl $url"?year="$y"-"$m
sleep 5s
for f in ${groupfrom[@]}
do
/usr/bin/curl $url"?year="$y"-"$m"&groupfrom="$f
sleep 5s
done
done
done
sleep 5s代表该脚本休眠5秒(脚本运行的时候每5s执行一次),测试的时候把/usr/bin/curl替换为echo,输出的应该是一个正常的http地址,如果能正常访问项目内的方法就可以了。
然后咱们写一个crontab的定时任务,先简单介绍一下五个星星分别表示什么,从前到后:
minute - 分钟 ,从0到59之间的任何整数
hour - 小时, 从0到23之间的任何整数
day - 天, 从1到31之间的任何整数(如果指定了月份,必须是该月份的有效日期)
month - 月份, 从1到12之间的任何整数(或使用月份的英文简写如jan/feb等等)
dayofweek - 星期 , 从0到7之间的任何整数,这里的0到7代表星期日(或者星期的英文简写如sun/mon等等)
好,介绍完之后咱们开始写(写的时候注意要用root权限 sudo crontab -e )
*/15 * * * * /bin/sh /Applications/MAMP/htdocs/localhosttest/test.sh
PS:每15分钟执行一次test.sh脚本 [即每个小时的第0 15 30 45 60分钟执行命令,也可每分钟,每小时,每天,每10天去执行一次 ],需要给test.sh和test.php 可执行的权限。(否则因为权限导致不执行)chmod +x test.php/test.sh
测试,执行成功!