常用命令
crontab -e #打开编辑计划任务,和用vim工具一样
crontab -l #查看计划任务
每月每天每小时的第 0 分钟执行一次 /bin/ls
0 * * * * /bin/ls
在 12 月内, 每天的早上 6 点到 12 点,每隔 3 个小时 0 分钟执行一次 /usr/bin/backup
0 6-12/3 * 12 * /usr/bin/backup
周一到周五每天下午 5:00 寄一封信给 alex@domain.name
0 17 * * 1-5 mail -s "hi" alex@domain.name < /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 设备,不看
& 最后带个 & 表示后台运行,写开机自启脚本时候建议 加 &
tail -f /var/log/cron #监控日志 "/var/log/cron" 是crontab的日志路径
#从日志里能看出,每分钟的第一秒,该脚本都会被执行一次。
/dev/null 表示空设备文件
0 表示stdin标准输入
1 表示stdout标准输出
2 表示stderr标准错误
对于2>&1的理解,2就是标准错误,1是标准输出,那么这条命令不就是相当于把标准错误重定向到标准输出
案例1,重定向错误输出到文件里
案例2 标准错误输出都重定向到文件
案例3 错误输出重定向到标准输出
#nginx -V 是错误输出,而grep 是不处理 错误输出的,这样我们找模块就比较麻烦了
#我把语句改了一下 把错误输出都输出到标准里,这样grep 就能处理了
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。