标签:
一. Crontab 介绍crontab命令的功能是在一定的时间间隔调度一些命令的执行。1.1 /etc/crontab 文件在/etc目录下有一个crontab文件,这里存放有系统运行的一些调度程序。每个用户可以建立自己的调度crontab。如:[root@dave ~]# cat /etc/crontabSHELL=/bin/bashPATH=/sbin:/bin:/usr/sbin:/usr/binMAILTO=rootHOME=/# run-parts01 * * * * root run-parts /etc/cron.hourly02 4 * * * root run-parts /etc/cron.daily22 4 * * 0 root run-parts /etc/cron.weekly42 4 1 * * root run-parts /etc/cron.monthly1.2 /etc/cron.deny 和 /etc/cron.allow 文件/etc/cron.deny 表示不能使用crontab 命令的用户/etc/cron.allow 表示能使用crontab的用户。如果两个文件同时存在,那么/etc/cron.allow 优先。如果两个文件都不存在,那么只有超级用户可以安排作业。每个用户都会生成一个自己的crontab 文件。这些文件在/var/spool/cron目录下:如:[root@dave ~]# cd /var/spool/cron[root@dave cron]# lsoracle root我们直接查看这个文件,里面的内容和对应用户显示的crontab -l 一致。[root@dave cron]# cat oracle00 6 * * * /u02/scripts/del_st_archive.sh >/u02/scripts/del_st_arch.log 2>&1
[root@dave cron]# cat root0 12 * * * /root/bin/sync-clock.sh[root@dave cron]#二. Crontab 使用说明2.1 Crontab语法usage: crontab [-u user] filecrontab [-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)其中,file是命令文件的名字。如果在命令行中指定了这个文件,那么执行crontab命令,则将这个文件拷贝到crontabs目录下;如果在命令行中没有制定这个文件,crontab命令将接受标准输入(键盘)上键入的命令,并将他们也存放在crontab目录下。帮助:[root@dave ~]# man crontabCRONTAB(1) CRONTAB(1)NAMEcrontab - maintain crontab files for individual users (ISC Cron V4.1)SYNOPSIScrontab [-u user] filecrontab [-u user] [-l | -r | -e] [-i] [-s]DESCRIPTIONCrontab is the program used to install, deinstall or list the tables used to drive the cron(8) daemon in ISC Cron. Each user can have their own crontab, and though these are files in /var/spool/ , they are not intended to be edited directly. For SELinux in mls mode can be even more crontabs - for each range. For more see selinux(8).If the cron.allow file exists, then you must be listed therein in order to be allowed to use this command. If the cron.allow file does not exist but the cron.deny file does exist, then you must not be listed in the cron.deny file in order to use this command. If neither of these files exists, only the super user will be allowed to use this command.OPTIONS-u It specifies the name of the user whose crontab is to be tweaked. If this option is not given, crontab examines "your" crontab, i.e., the crontab of the person executing the command. Note that su(8) can confuse crontab and that if you are running inside of su(8) you should always use the -u option for safety?ˉs sake. The first form of this command is used to install a new crontab from some named file or standard input if the pseudo-filename "-" is given.-l The current crontab will be displayed on standard output.-r The current crontab will be be removed.-e This option is used to edit the current crontab using the editor specified by the VISUAL or EDITOR environment variables. After you exit from the edi-tor, the modified crontab will be installed automatically.
-i This option modifies the -r option to prompt the user for a ?ˉy/Y?ˉ response before actually removing the crontab.-s It will append the current SELinux security context string as an MLS_LEVEL setting to the crontab file before editing / replacement occurs - see the documentation of MLS_LEVEL in crontab(5).SEE ALSOcrontab(5), cron(8)FILES/etc/cron.allow/etc/cron.denySTANDARDSThe crontab command conforms to IEEE Std1003.2-1992 (????POSIX?ˉ?ˉ). This new command syntax differs from previous versions of Vixie Cron, as well as from the classicSVR3 syntax.DIAGNOSTICSA fairly informative usage message appears if you run it with a bad command line.AUTHORPaul Vixie <vixie@isc.org>4th Berkeley Distribution 16 Januar 2007 CRONTAB(1)2.2 Crontab 格式说明我们可以用crontab -e 添加要执行的命令。 命令执行的结果,无论是标准输出还是错误输出,都将以邮件形式发给用户。添加的命令必须以如下格式:* * * * * /command path前五个字段可以取整数值,指定何时开始工作,第六个域是字符串,即命令字段,其中包括了crontab调度执行的命令。 各个字段之间用spaces和tabs分割。前5个字段分别表示:分钟:0-59小时:1-23日期:1-31月份:1-12星期:0-6(0表示周日)还可以用一些特殊符号:*: 表示任何时刻,: 表示分割-:表示一个段,如第二端里: 1-5,就表示1到5点/n : 表示每个n的单位执行一次,如第二段里,*/1, 就表示每隔1个小时执行一次命令。也可以写成1-23/1.一些示例:00 8,12,16 * * * /data/app/scripts/monitor/df.sh
30 2 * * * /data/app/scripts/hotbackup/hot_database_backup.sh
10 8,12,16 * * * /data/app/scripts/monitor/check_ind_unusable.sh
10 8,12,16 * * * /data/app/scripts/monitor/check_maxfilesize.sh
10 8,12,16 * * * /data/app/scripts/monitor/check_objectsize.sh
43 21 * * * 21:43 执行15 05 * * * 05:15 执行0 17 * * * 17:00 执行0 17 * * 1 每周一的 17:00 执行0,10 17 * * 0,2,3 每周日,周二,周三的 17:00和 17:10 执行0-10 17 1 * * 毎月1日从 17:00到7:10 毎隔1分钟 执行0 0 1,15 * 1 毎月1日和 15日和 一日的 0:00 执行42 4 1 * * 毎月1日的 4:42分 执行0 21 * * 1-6 周一到周六 21:00 执行0,10,20,30,40,50 * * * * 每隔10分 执行*/10 * * * * 每隔10分 执行* 1 * * * 从1:0到1:59 每隔1分钟 执行0 1 * * * 1:00 执行0 */1 * * * 毎时0分 每隔1小时 执行0 * * * * 毎时0分 每隔1小时 执行2 8-20/3 * * * 8:02,11:02,14:02,17:02,20:02 执行30 5 1,15 * * 1日 和 15日的 5:30 执行2.3 & 后台执行命令当在前台运行某个作业时,终端被该作业占据;而在后台运行作业时,它不会占据终端。可以使用&命令把作业放到后台执行。如:30 2 * * * /data/app/scripts/hotbackup/hot_database_backup.sh &
在后台运行作业时要当心:需要用户交互的命令不要放在后台执行,因为这样你的机器就会在那里傻等。不过,作业在后台运行一样会将结果输出到屏幕上,干扰你的工作。如果放在后台运行的作业会产生大量的输出,最好使用下面的方法把它的输出重定向到某个文件中:如:command >out.file 2>&1 &在这个例子中,2>&1表示所有的标准输出和错误输出都将被重定向到一个叫做out.file 的文件中。2.4 2>&1 含义先看一个例子:0 2 * * * /u01/test.sh >/dev/null 2>&1 &
这句话的意思就是在后台执行这条命令,并将错误输出2重定向到标准输出1,然后将标准输出1全部放到/dev/null 文件,也就是清空。
在这里有有几个数字的意思:0表示键盘输入1表示标准输出2表示错误输出.我们也可以这样写:0 2 * * * /u01/test.sh >/u01/out.file & --这里没写,默认是10 2 * * * /u01/test.sh 1>/u01/out.file &0 2 * * * /u01/test.sh 2>/u01/out.file &0 2 * * * /u01/test.sh 2>/u01/out.file 2>&1 &将tesh.sh 命令输出重定向到out.file, 即输出内容不打印到屏幕上,而是输出到out.file文件中。2>&1 是将错误输出重定向到标准输出。 然后将标准输入重定向到文件out.file。&1 表示的是文件描述1,表示标准输出,如果这里少了&就成了数字1,就表示重定向到文件1。& :后台执行测试:ls 2>1 : 不会报没有2文件的错误,但会输出一个空的文件1;ls xxx 2>1: 没有xxx这个文件的错误输出到了1中;ls xxx 2>&1: 不会生成1这个文件了,不过错误跑到标准输出了;ls xxx >out.txt 2>&1 == ls xxx 1>out.txt 2>&1; 因为重定向符号>默认是1,这句就把错误输出和标准输出都传到out.txt 文件中。2.5 2>&1写在后面的原因格式:command > file 2>&1 == command 1> file 2>&1首先是command > file将标准输出重定向到file中, 2>&1 是标准错误拷贝了标准输出,也就是同样被重定向到file中,最终结果就是标准输出和错误都被重定向到file中。如果改成: command 2>&1 >file2>&1 标准错误拷贝了标准输出的行为,但此时标准输出还是在终端。>file 后输出才被重定向到file,但标准错误仍然保持在终端。
标签:
原文地址:http://www.cnblogs.com/hellojesson/p/5770767.html