1.格式写法


常用命令
crontab -e #打开编辑计划任务,和用vim工具一样
crontab -l #查看计划任务

2.实例

每月每天每小时的第 0 分钟执行一次 /bin/ls

0 * * * * /bin/ls
在 12 月内, 每天的早上 6 点到 12 点,每隔 3 个小时 0 分钟执行一次 /usr/bin/backup

0 6-12/3 * 12 * /usr/bin/backup
周一到周五每天下午 5:00 寄一封信给 [email protected]

0 17 * * 1-5 mail -s "hi" [email protected] < /tmp/maildata
每月每天的午夜 0 点 20 分, 2 点 20 分, 4 点 20 分....执行 echo "haha"

20 0-23/2 * * * echo "haha"

下面再看看几个具体的例子:

0 */2 * * * /sbin/service httpd restart  意思是每两个小时重启一次apache 

50 7 * * * /sbin/service sshd start  意思是每天7:50开启ssh服务 

50 22 * * * /sbin/service sshd stop  意思是每天22:50关闭ssh服务 

0 0 1,15 * * fsck /home  每月1号和15号检查/home 磁盘 

1 * * * * /home/bruce/backup  每小时的第一分执行 /home/bruce/backup这个文件 

00 03 * * 1-5 find /home "*.xxx" -mtime +4 -exec rm {} \;  每周一至周五3点钟,在目录/home中,查找文件名为*.xxx的文件,并删除4天前的文件。

30 6 */10 * * ls  意思是每月的1、11、21、31日是的6:30执行一次ls命令

运行脚本实例

#表示每1分钟运行一次脚本,注意脚本路径写决定路径且要给脚本X 运行权限,

/dev/null 表示把脚本所产生的输出无论是标准的还是错误的全部送给 null 设备,不看
& 最后带个 & 表示后台运行,写开机自启脚本时候建议 加 &

3.查看日志

tail -f /var/log/cron #监控日志 "/var/log/cron" 是crontab的日志路径

#从日志里能看出,每分钟的第一秒,该脚本都会被执行一次。

4. 2>&1 几个基本符号及其含义

/dev/null 表示空设备文件
0 表示stdin标准输入
1 表示stdout标准输出
2 表示stderr标准错误
对于2>&1的理解,2就是标准错误,1是标准输出,那么这条命令不就是相当于把标准错误重定向到标准输出

案例1,重定向错误输出到文件里

案例2 标准错误输出都重定向到文件

案例3 错误输出重定向到标准输出

#nginx -V 是错误输出,而grep 是不处理 错误输出的,这样我们找模块就比较麻烦了


#我把语句改了一下 把错误输出都输出到标准里,这样grep 就能处理了


#实例,运行脚本的时候有些错误不想让它显示,就输出到/dev/null