crontab结合用PHP编写的shell完成自动更新数据的程序

crontab结合用PHP编写的shell完成自动更新数据的程序

另外可以参看: http://www.cnblogs.com/candle806/archive/2011/12/15/2288491.html


作者:心灯
1.用PHP编写编写shell
getscore.php
#!/usr/local/bin/php -q
<?
$g_dbhost = "localhost";
$g_dbname = "16328";
$g_dbuserid = "root";
$g_dbpasswd = "";
function opendb(){
global $g_dbhost, $g_dbuserid, $g_dbpasswd, $g_dbname, $g_errmsg;
$conn = mysql_connect($g_dbhost,$g_dbuserid,$g_dbpasswd);
if(!$conn) die($g_errmsg.mysql_error());
@mysql_select_db($g_dbname, $conn);
if(mysql_errno()) die($g_errmsg.mysql_error());
return $conn;
}
opendb();
$date = date("Y-m-d");
$time = date("H:i:s");
echo $sql = "insert into football_rate set fr_date='$date',fr_time='$time'";
$res = mysql_query($sql) or die(mysql_error());
?>

数据库:
CREATE TABLE `16328` (
`fr_date` date NOT NULL default '0000-00-00',
`fr_time` varchar(32) NOT NULL default ''
) ENGINE=MyISAM DEFAULT CHARSET=latin1;

2.设定crontab
执行 vi /etc/crontab 命令

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
#這裡預設是 root ,crond 執行完之後會將結果寄給這個帳號,我們可以自取,不過需要事先建立這個帳號
HOME=/

# run-parts
* * * * * root /home/bjbs270/public_html/getscore.php # 每一分钟执行一次所指定的程序
01 * * * * root run-parts /etc/cron.hourly
02 4 * * * root run-parts /etc/cron.daily
22 4 * * 0 root run-parts /etc/cron.weekly
42 4 1 * * root run-parts /etc/cron.monthly

3.重启crond
/etc/rc.d/init.d/crond start/stop/restart

附:

Crontab是UNIX系统下的定时任务触发器,其使用者的权限记载在下列两个文件中:
/usr/var/adm/cron/cron.deny:该文件中所列的用户不允许使用Crontab命令;
/usr/var/adm/cron/cron.allow:该文件中所列的用户允许使用Crontab命令;
Crontab命令的格式为:crontab –l|-v|-r|-e [username],其参数含义如表一:

参数名称

含义

-l

显示用户的Crontab文件的内容

-v

显示用户的Crontab文件的内容及其提交的时间,只适用于Compaq系列

-r

Crontab目录中删除用户的Crontab文件

-e

编辑用户的Crontab文件



用户所建立的Crontab文件存于/var/spool/cron/crontabs中,其文件名与用户名一致。
它的格式共分为六段,前五段为时间设定段,第六段为所要执行的命令段,
格式如下:* * * * * <command>

其时间段的含义如表二:

含义

取值范围

第一段

代表分钟

0—59

第二段

代表小时

0—23

第三段

代表日期

1—31

第四段

代表月份

1—12

第五段

代表星期几,0代表星期日

0—6

例:如果用户的Crontab文件的内容是:29 19 * * * echo its dinner time,则系统每天的19:29显示‘its dinner time’。
附:当这六段什么都不设的话就是程序在1秒中执行一次
我在用CRON的时候把“01 ** * * 命令1”当成了是每一秒中程序执行一次命令一。这个想法误导了我很久,其实这句话的意思是每个小时的第一分钟程序执行一次。

修改 /etc/crontab 和 crontab -e 指令有何不同?

  • /etc/crontab 的設定是針對整個系統,只有 root 才有權限修改
  • crontab -e 的設定是針對個人 用 crontab -e 建的個人排程會放在 /var/spool/cron/ 下
    • crontab -e
      //編輯排程
    • crontab -r
      // 刪除排程
    • crontab -l
      // 列出排程
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值