当前位置:K88软件开发文章中心编程语言LinuxLinux01 → 文章内容

linux自动任务 crontab命令

减小字体 增大字体 作者:佚名  来源:网上搜集  发布时间:2019-1-4 9:03:14

子进行相应的修改。为了提交你刚刚创建的crontab文件,可以把这个新创建的文件作为cron命令的参数:

$?crontab?davecron

现在该文件已经提交给cron进程,它将每隔1?5分钟运行一次。

同时,新创建文件的一个副本已经被放在/var/spool/cron目录中,文件名就是用户名(即dave)。

2).?列出crontab文件

为了列出crontab文件,可以用:

$?crontab?-l

0,15,30,45,18-06?*?*?*?/bin/echo?`date`?>?dev/tty1

你将会看到和上面类似的内容。可以使用这种方法在$?H?O?M?E目录中对crontab文件做一备份:

$?crontab?-l?>?$HOME/mycron

这样,一旦不小心误删了crontab文件,可以用上一节所讲述的方法迅速恢复。

3).?编辑crontab文件

如果希望添加、删除或编辑crontab文件中的条目,而E?D?I?TO?R环境变量又设置为v?i,那么就可以用v?i来编辑crontab文件,相应的命令为:

$?crontab?-e

可以像使用v?i编辑其他任何文件那样修改crontab文件并退出。如果修改了某些条目或添加了新的条目,那么在保存该文件时,?c?r?o?n会对其进行必要的完整性检查。如果其中的某个域出现了超出允许范围的值,它会提示你。

我们在编辑crontab文件时,没准会加入新的条目。例如,加入下面的一条:

#?DT:delete?core?files,at?3.30am?on?1,7,14,21,26,26?days?of?each?month

30?3?1,7,14,21,26?*?*?/bin/find?-name?“core’?-exec?rm?{}?\;

现在保存并退出。最好在crontab文件的每一个条目之上加入一条注释,这样就可以知道它的功能、运行时间,更为重要的是,知道这是哪位用户的作业。

现在让我们使用前面讲过的crontab?-l命令列出它的全部信息:

$?crontab?-l

#?(crondave?installed?on?Tue?May?4?13:07:43?1999)

#?DT:ech?the?date?to?the?console?every?30?minites

0,15,30,45?18-06?*?*?*?/bin/echo?`date`?>?/dev/tty1

#?DT:delete?core?files,at?3.30am?on?1,7,14,21,26,26?days?of?each?month

30?3?1,7,14,21,26?*?*?/bin/find?-name?“core’?-exec?rm?{}?\;

4).?删除crontab文件

要删除crontab文件,可以用:

$?crontab?-r

5).?恢复丢失的crontab文件

如果不小心误删了crontab文件,假设你在自己的$?H?O?M?E目录下还有一个备份,那么可以将其拷贝到/var/spool/cron/<username>,其中<username>是用户名。如果由于权限问题无法完成拷贝,可以用:

$?crontab?<filename>

其中,<filename>是你在$?H?O?M?E目录中副本的文件名。

我建议你在自己的$?H?O?M?E目录中保存一个该文件的副本。我就有过类似的经历,有数次误删了crontab文件(因为r键紧挨在e键的右边)。这就是为什么有些系统文档建议不要直接编辑crontab文件,而是编辑该文件的一个副本,然后重新提交新的文件。

有些crontab的变体有些怪异,所以在使用crontab命令时要格外小心。如果遗漏了任何选项,crontab可能会打开一个空文件,或者看起来像是个空文件。这时敲delete键退出,不要按<Ctrl-D>,否则你将丢失crontab文件。

5.使用实例

实例1:每1分钟执行一次command

命令:

*?*?*?*?*?command

实例2:每小时的第3和第15分钟执行

命令:

3,15?*?*?*?*?command

实例3:在上午8点到11点的第3和第15分钟执行

命令:

3,15?8-11?*?*?*?command

实例4:每隔两天的上午8点到11点的第3和第15分钟执行

命令:

3,15?8-11?*/2?*?*?command

实例5:每个星期一的上午8点到11点的第3和第15分钟执行

命令:

3,15?8-11?*?*?1?command

实例6:每晚的21:30重启smb

命令:

30?21?*?*?*?/etc/init.d/smb?restart

实例7:每月1、10、22日的4?:?45重启smb

命令:

45?4?1,10,22?*?*?/etc/init.d/smb?restart

实例8:每周六、周日的1?:?10重启smb

命令:

10?1?*?*?6,0?/etc/init.d/smb?restart

实例9:每天18?:?00至23?:?00之间每隔30分钟重启smb

命令:

0,30?18-23?*?*?*?/etc/init.d/smb?restart

实例10:每星期六的晚上11?:?00?pm重启smb

命令:

0?23?*?*?6?/etc/init.d/smb?restart

实例11:每一小时重启smb

命令:

*?*/1?*?*?*?/etc/init.d/smb?restart

实例12:晚上11点到早上7点之间,每隔一小时重启smb

命令:

*?23-7/1?*?*?*?/etc/init.d/smb?restart

实例13:每月的4号与每周一到周三的11点重启smb

命令:

0?11?4?*?mon-wed?/etc/init.d/smb?restart

实例14:一月一号的4点重启smb

命令:

0?4?1?jan?*?/etc/init.d/smb?restart

实例15:每小时执行/etc/cron.hourly目录内的脚本

命令:

01???*???*???*???*?????root?run-parts?/etc/cron.hourly

说明:

run-parts这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是目录名了

四、使用注意事项

1.?注意环境变量问题

有时我们创建了一个crontab,但是这个任务却无法自动执行,而手动执行这个任务却没有问题,这种情况一般是由于在crontab文件中没有配置环境变量引起的。

在crontab文件中定义多个调度任务时,需要特别注意的一个问题就是环境变量的设置,因为我们手动执行某个任务时,是在当前shell环境下进行的,程序当然能找到环境变量,而系统自动执行任务调度时,是不会加载任何环境变量的,因此,就需要在crontab文件中指定任务运行所需的所有环境变量,这样,系统执行任务调度时就没有问题了。

不要假定cron知道所需要的特殊环境,它其实并不知道。所以你要保证在shelll脚本中提供所有必要的路径和环境变量,除了一些自动设置的全局变量。所以注意如下3点:

1)脚本中涉及文件路径时写全局路径;

2)脚本执行要用到java或其他环境变量时,通过source命令引入环境变量,如:

cat?start_cbp.sh

#!/bin/sh

source?/etc/profile

export?RUN_CONF=/home/d139/conf/platform/cbp/cbp_jboss.conf

/usr/local/jboss-4.0.5/bin/run.sh?-c?mev?&

3)当手动执行脚本OK,但是crontab死活不执行时。这时必须大胆怀疑是环境变量惹的祸,并可以尝试在crontab中直接引入环境变量解决问题。如:

0?*?*?*?*?.?/etc/profile;/bin/sh?/var/www/java/audit_no_count/bin/restart_audit.sh

2.?注意清理系统用户的邮件日志

每条任务调度执行完毕,系统都会将任务输出信息通过电子邮件的形式发送给当前系统用户,这样日积月累,日志信息会非常大,可能会影响系统的正常运行,因此,将每条任务进行重定向处理非常重要。

例如,可以在crontab文件中设置如下形式,忽略日志输出:

0?*/3?*?*?*?/usr/local/apache2/apac

上一页  [1] [2] [3]  下一页


linux自动任务 crontab命令