Linux系统中,计划任务一般是由cron承担,我们可以把cron设置为开机时自动启动。cron启动后,它会读取它的所有配置文件(全局性配置文件/etc/crontab,以及每个用户的计划任务配置文件),然后cron会根据命令和执行时间来按时来调用度工作任务。


cron 是一个可以用来根据时间、日期、月份、星期的组合来调度对重复任务的执行的守护进程。

cron 假定系统持续运行。如果当某任务被调度时系统不在运行,该任务就不会被执行。

vixie-cron RPM 软件包,而且必须在运行 crond 服务。要判定该软件包是否已安装,使用 rpm -q vixie-cron 命令。要判定该服务是否在运行,使用 /sbin/service crond status

配置 cron 任务


/etc/crontab,它包括下面几行:

SHELL=/bin/bash                  PATH=/sbin:/bin:/usr/sbin:/usr/bin                  MAILTO=root                  HOME=/                  # run-parts                  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

SHELL 变量的值告诉系统要使用哪个 shell 环境(在这个例子里是 bash shell);PATH 变量定义用来执行命令的路径。cron 任务的输出被邮寄给 MAILTO 变量定义的用户名。如果MAILTO 变量被定义为空白字符串(MAILTO=""),电子邮件就不会被寄出。HOME


/etc/crontab

minute         hour         day         month         dayofweek         command

 

  • minute
  • hour
  • day
  • month
  • dayofweek
  • command — 要执行的命令(命令可以是 ls /proc >> /tmp/proc

在以上任何值中,星号(*)可以用来代表所有有效的值。譬如,月份值中的星号意味着在满足其它制约条件后每月都执行该命令。

1-4

3, 4, 6, 8

/<integer> 意味着在范围内可以跳过 integer。譬如,0-59/2 可以用来在分钟字段定义每两分钟。间隔频率值还可以和星号一起使用。例如,*/3

开头为井号(#)的行是注释,不会被处理。

/etc/crontab 文件中所见,它使用 run-parts 脚本来执行/etc/cron.hourly、/etc/cron.daily、/etc/cron.weekly 和 /etc/cron.monthly

/etc/cron.d 目录中。该目录中的所有文件使用和 /etc/crontab




# record the memory usage of the system every monday                  # at 3:30AM in the file /tmp/meminfo                  30 3 * * mon cat /proc/meminfo >> /tmp/meminfo                  # run custom script the first day of every month at 4:10AM                  10 4 1 * * /root/scripts/backup.sh


crontab 的例子


crontab 工具来配置 cron 任务。所有用户定义的 crontab 都被保存在/var/spool/cron 目录中,并使用创建它们的用户身份来执行。要以某用户身份创建一个 crontab 项目,登录为该用户,然后键入 crontab -e 命令,使用由 VISUAL 或 EDITOR 环境变量指定的编辑器来编辑该用户的 crontab。该文件使用的格式和 /etc/crontab 相同。当对 crontab 所做的改变被保存后,该 crontab 文件就会根据该用户名被保存,并写入文件 /var/spool/cron/username

/etc/crontab 文件、etc/cron.d/ 目录、以及 /var/spool/cron


cron服务提供crontab命令来设定cron服务的,以下是这个命令的一些参数与说明:

  crontab -u //设定某个用户的cron服务,一般root用户在执行这个命令的时候需要此参数

  crontab -l //列出某个用户cron服务的详细内容

  crontab -r //删除没个用户的cron服务

  crontab -e //编辑某个用户的cron服务

  比如说root查看自己的cron设置:crontab -u root -l


  再例如,root想删除fred的cron设置:crontab -u fred -r

crontab文件的一些例子:

30 21 * * * /usr/local/etc/rc.d/lighttpd restart
 上面的例子表示每晚的21:30重启apache。
 45 4 1,10,22 * * /usr/local/etc/rc.d/lighttpd restart
 上面的例子表示每月1、10、22日的4 : 45重启apache。
 10 1 * * 6,0 /usr/local/etc/rc.d/lighttpd restart
 上面的例子表示每周六、周日的1 : 10重启apache。
 0,30 18-23 * * * /usr/local/etc/rc.d/lighttpd restart
 上面的例子表示在每天18 : 00至23 : 00之间每隔30分钟重启apache。
 0 23 * * 6 /usr/local/etc/rc.d/lighttpd restart
 上面的例子表示每星期六的11 : 00 pm重启apache。
 * */1 * * * /usr/local/etc/rc.d/lighttpd restart
 每一小时重启apache
 * 23-7/1 * * * /usr/local/etc/rc.d/lighttpd restart
 晚上11点到早上7点之间,每隔一小时重启apache
 0 11 4 * mon-wed /usr/local/etc/rc.d/lighttpd restart
 每月的4号与每周一到周三的11点重启apache
 0 4 1 jan * /usr/local/etc/rc.d/lighttpd restart
 一月一号的4点重启apache


控制对 cron 的使用

/etc/cron.allow 和 /etc/cron.deny 文件被用来限制对 cron 的使用。这两个使用控制文件的格式都是每行一个用户。两个文件都不允许空格。如果使用控制文件被修改了,cron 守护进程(crond)不必被重启。使用控制文件在每次用户添加或删除一项 cron 任务时都会被读取。

无论使用控制文件中的规定如何,根用户都总是可以使用 cron。

cron.allow 文件存在,只有其中列出的用户才被允许使用 cron,并且 cron.deny

cron.allow 文件不存在,所有在 cron.deny

启动和停止服务

/sbin/service crond start 命令。要停止该服务,使用 /sbin/service crond stop

 

由于Cron 是Linux的内置服务,可以用以下的方法启动、关闭这个服务:

/sbin/service crond start //启动服务
 /sbin/service crond stop //关闭服务
 /sbin/service crond restart //重启服务
 /sbin/service crond reload //重新载入配置

。。。。。

 


crontab在/etc目录下面存在cron.d,cron.daily,cron.weekly,cron.monthly,cron.hourly五个目录和crontab,cron.deny二个文件。

cron.daily是每天执行一次的job,cron.weekly是每个星期执行一次的job.
cron.monthly是每月执行一次的job,cron.hourly是每个小时执行一次的job.

cron.d是系统自动定期需要做的任务,但是又不是按小时,按天,按星期,按月来执行的,那么就放在这个目录下面。
如果是按小时,按天,按星期,按月的来执行的话,则可以放到前面相应的目录下面去。


那么有人也许会问,前面按天,按星期,按月执行的job,到底是什么时候去自动执行呢?
通过察看/etc/crontab文件就很清楚了:

[admin@c2c_std etc]$ cat crontab
 SHELL=/bin/bash
 PATH=/sbin:/bin:/usr/sbin:/usr/bin
 MAILTO=root
 HOME=/# run-parts
 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

/etc/cron.deny文件就是用于控制不让哪些用户使用Crontab的功能。


另外在/var/spool下面存在着两个目录cron,anacron。
其中cron目录下面有每个用户的自己通过crontab -e增加的crontab的内容。

anacron目录下面是记录的是cron.daily,cron.monthly,cron.weekly的上一次执行的时间。


linux的cron服务是每隔一分钟去读取一次/var/spool/cron,/etc/crontab,/etc/cron.d下面所有的内容。


在linux系统上,默认情况下在/etc/cron.daily目录下面存在以下文件:

-rwxr-xr-x 1 root root 286 Aug 14 2004 tmpwatch
 -rwxr-xr-x 1 root root 276 Sep 29 2004 0anacron
 -rwxr-xr-x 1 root root 2133 Dec 1 2004 prelink
 -rwxr-xr-x 1 root root 180 Jul 13 2005 logrotate
 -rwxr-xr-x 1 root root 121 Aug 9 2005 slocate.cron
 -rwxr-xr-x 1 root root 48 Apr 10 2006 mcelog.cron
 -rwxr-xr-x 1 root root 418 Apr 14 2006 00-makewhatis.cron
 -rwxr-xr-x 1 root root 104 May 31 2006 rpm
 lrwxrwxrwx 1 root root 28 Apr 7 08:25 00-logwatch -> ../log.d/scripts/logwatch.pl

这里有些东西是很耗资源的,可以考虑去掉。
tmpwatch的作用是清除掉一些长时间没有访问的临时文件。这个留着。
0anacron的作用是更新crontab job的执行时间,这个必须要留着。它在名称的前面另上0,以保证这个程序会在
其他程序前执行。并且这个被run-parts自动调用。

prelink的作用是预链接一些动态链接库和可执行文件,以此来加快启动时间和减少run-time的内存分配,有点类似于oracle
的dbms_shared_pool.keep的作用一样。这个东西是个双刃剑。

logrotate的作用循环利用,压缩一些系统日志的,还是留着。

slocate.cron的作用更新slocate database,用于为locate服务的,很消耗资源,可以停掉。

mcelog.cron的作用是用于生成/var/log/mcelog文件,留着。

00-makewhatis.cron的作用是创建whatis database,用于为whatis服务的。较为消耗资源,可以去掉。
这个在cron.weekly里面也存在,这里面的也可以去掉。

rmp的作用是每天将系统上安装过的rpm包的信息放到/var/log/rpmpkgs中去。这个没什么用处,可以去掉。

00-logwatch 的作用是用于监控linux log文件的。可以留着。