cron 的主配置文件是 /etc/crontab,它包括一下内容
[root@hadoop spool]# cat /etc/crontab
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root #计划任务执行时会通过mail发送日志信息给执行用户,对应路径/var/spool/mail
HOME=/
# For details see man 4 crontabs
# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed
PS:
CONTENT | DESCRIBE |
---|---|
SHELL=/bin/bash | 告诉系统要使用哪个 shell 环境 |
PATH=/sbin:/bin:/usr/sbin:/usr/bin | PATH 变量定义用来执行命令的路径 |
MAILTO=root | cron 任务的输出被邮寄给MAILTO 变量定义的用户名。若为空,电子邮件就不会被寄出 |
HOME=/ | 用来设置在执行命令或脚本时使用的主目录 |
minute hour day month dayofweek command
CONTENT | DESCRIBE |
---|---|
minute — 分钟 | 从 0 到 59 之间的任何整数 |
hour — 小时 | 从 0 到 23 之间的任何整数 |
day — 日期 | 从 1 到 31 之间的任何整数(如果指定了月份,必须是该月份的有效日期) |
month — 月份 | 从 1 到 12 之间的任何整数(或使用月份的英文简写如 jan、feb 等等) |
dayofweek — 星期 | 从 0 到 7 之间的任何整数,这里的 0 或 7 代表星期日(或使用星期的英文简写如 sun、mon 等等) |
command — 要执行的命令 | (命令可以是ls /proc >> /tmp/proc 之类的命令,也可以是执行你自行编写的脚本的命令。) |
通过命令行我们可以看到工具中的参数有如下这些:
[root@hadoop mail]# crontab -help
crontab: invalid option -- 'h'
crontab: usage error: unrecognized option
usage: crontab [-u user] file
crontab [-u user] [ -e | -l | -r ]
(default operation is replace, per 1003.2)
-e (edit user's crontab)
-l (list user's crontab)
-r (delete user's crontab)
-i (prompt before deleting user's crontab)
-s (selinux context)
PS:常用参数说明
参数 | 说明 |
---|---|
-u | 执行计划任务的用户 |
-e | 编辑用户的计划任务 |
-l | 产看用户的计划任务列表 |
-i | 删除用户计划任务前提示 |
使用举例:
[root@hadoop mail]# crontab -e
[root@hadoop mail]# crontab -l #没有指定用户时,默认为当前用户的计划任务
*/1 * * * * echo "Hello root"
[root@hadoop mail]# crontab -l -u hadoop
*/1 * * * * echo "Hello"
所有用户定义的 crontab 都被保存在/var/spool/cron 目录中,并使用创建它们的用户身份来执行。这个文件中的内容跟执行命令
crontab -l 看到的内容一样
[root@hadoop cron.d]# cat /var/spool/cron/root
*/1 * * * * date >> /tmp/log.txt
[root@hadoop cron]# crontab -l
*/1 * * * * echo "Hello root"
我们来对 /var/spool/cron/root 这个文件进行修改,看看会发生什么。
[root@hadoop cron.d]# vi /var/spool/cron/root
在这个文件中的末尾加上 #End of File。
再执行 crontab -l 看到增加的内容出现了!
[root@hadoop cron.d]# crontab -l
*/1 * * * * date >> /tmp/log.txt
#End of File
结论:利用 crontab 命令对用户的计划认为进行修改时,实际上修改的文件是 /var/spool/cron 这个路径下对应用户名的文件。例如:用户root利用 crontab -e 添加了一条计划任务,则在 /var/spool/cron 路径下就有一个以用户名命名的文件,这里是root,其中就多了一行记录。
[root@hadoop mail]# tail -f /var/log/cron
Aug 9 12:14:01 hadoop CROND[4550]: (hadoop) CMD (echo "Hello")
Aug 9 12:14:01 hadoop CROND[4544]: (hadoop) MAIL (mailed 6 bytes of output but got status 0x007f#012)
Aug 9 12:15:01 hadoop CROND[4557]: (root) CMD (echo "Hello")
Aug 9 12:15:01 hadoop CROND[4558]: (hadoop) CMD (echo "Hello")
Aug 9 12:15:01 hadoop CROND[4554]: (root) MAIL (mailed 6 bytes of output but got status 0x007f#012)
Aug 9 12:15:01 hadoop CROND[4553]: (hadoop) MAIL (mailed 6 bytes of output but got status 0x007f#012)
Aug 9 12:16:01 hadoop CROND[4566]: (root) CMD (echo "Hello")
我们先来看一下Crontab在etc下的目录结构
[root@hadoop etc]# ls -l cron*
-rw-r--r--. 1 root root 0 Jul 19 2011 cron.deny
-rw-r--r--. 1 root root 457 Sep 27 2011 crontab
cron.d:
total 12
-rw-r--r--. 1 root root 113 Jul 19 2011 0hourly
-rw-r--r--. 1 root root 108 Dec 7 2012 raid-check
-rw-r--r--. 1 root root 229 Jun 22 2012 sysstat
cron.daily:
total 24
-rwxr-xr-x. 1 root root 196 Aug 16 2012 logrotate
-rwxr-xr-x. 1 root root 905 Feb 22 2013 makewhatis.cron
-rwxr-xr-x. 1 root root 174 Sep 24 2012 mlocate.cron
-rwxr-xr-x. 1 root root 2126 Apr 23 2010 prelink
-rwxr-xr-x. 1 root root 563 Aug 23 2010 readahead.cron
-rwxr-xr-x. 1 root root 365 Oct 16 2009 tmpwatch
cron.hourly:
total 4
-rwxr-xr-x. 1 root root 424 Jul 19 2011 0anacron
cron.monthly:
total 4
-rwxr-xr-x. 1 root root 111 Aug 23 2010 readahead-monthly.cron
cron.weekly:
total 0
然后来进行一下说明:
TASK | DESCRIBE |
---|---|
tmpwatch | 作用是清除掉一些长时间没有访问的临时文件。这个留着 |
0anacron | 作用是更新crontab job的执行时间,这个必须要留着。它在名称的前面另上0,以保证这个程序会在其他程序前执行。并且这个被run-parts自动调用。 |
prelink | 作用是预链接一些动态链接库和可执行文件,以此来加快启动时间和减少run-time的内存分配,有点类似于oracle的dbms_shared_pool.keep的作用一样。这个东西是个双刃剑 |
logrotate | 作用循环利用,压缩一些系统日志的,还是留着。 |
slocate.cron | 作用更新slocate database,用于为locate服务的,很消耗资源,可以停掉。 |
makewhatis.cron | 作用是创建whatis database,用于为whatis服务的。较为消耗资源,可以去掉。 |
第三和第五个域之间执行的是 “或” 操作
第三个域是某个月中的天,第五个域是某个月中的星期几
例如:四月的第一个星期日早晨 1 时 59 分运行 a.sh
分钟数设置错误
例如:每两小时运行一次
相关内容:
http://www.th7.cn/system/lin/201506/108389.shtml
http://blog.csdn.net/foxman209/article/details/6759920