Linux Crontab
时间格式和规则
* * * * *
- - - - -
| | | | |
| | | | +----- 星期中星期几 (0 - 7) (星期天 为0)
| | | +---------- 月份 (1 - 12)
| | +--------------- 一个月中的第几天 (1 - 31)
| +-------------------- 小时 (0 - 23)
+------------------------- 分钟 (0 - 59)
更多例子:
下面给出cron参数中各个参数的含义:
CRON表达式 含义
0 */2 * * * /sbin/service httpd restart 意思是每两个小时重启一次apache
50 7 * * * /sbin/service sshd start 意思是每天7:50开启ssh服务
50 22 * * * /sbin/service sshd stop 意思是每天22:50关闭ssh服务
0 0 1,15 * * fsck /home 每月1号和15号检查/home 磁盘
1 * * * * /home/bruce/backup 每小时的第一分执行 /home/bruce/backup这个文件
00 03 * * 1-5 find /home "*.xxx" -mtime +4 -exec rm {} \; 每周一至周五3点钟,在目录/home中,查找文件名为*.xxx的文件,并删除4天前的文件。
30 6 */10 * * ls 意思是每月的1、11、21、31日是的6:30执行一次ls命令
例子:
*/1 * * * * /usr/bin/php /var/www/html/tp5/application/api/controller/test/test.php >> /dev/null 2>&1
每1分钟执行一次, 这是通过 php 执行
>> /dev/null 2>&1
当程序在你所指定的时间执行后,系统会发一封邮件给当前的用户,显示该程序执行的内容,若是你不希望收到这样的邮件,请在每一行空一格之后加上 > /dev/null 2>&1
shell 脚本执行
shell 脚本通过 Curl 调用 项目里的方法, 可以通过携带参数来确保安全性; 上面的那一种方式, 在知道路径的情况下, 可以直接在浏览器中直接访问. 存在安全漏洞!
shell 脚本文件
#! /bin/sh
curl -d "md5=7f756291b099621605b46f3aa32ec26f" http://test.com/api/test/test.php
"md5" 的值传递到服务器, 服务器校验准确性!
Crontab 执行 shell 脚本
10 0 * * * /mnt/crontab/test.sh >> /mnt/crontab/test.log
写得简单,还可能会有不足的地方, 欢迎哥哥们指出不足!