linux自动任务 crontab命令
$?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
linux自动任务 crontab命令