linuxcron记录时间,crontab⽇志
查看crontab的⽇志记录定位定时任务问题
#### 1. linux观察当天最新的crontab⽇志记录
⽤`tail -f /var/log/cron`观察就可以。
#### 2. 查看某⽇期crontab⽇志记录
~~~
[root@iZ23w9ljtgdZ log]# ls cron*
cron cron-20180513 cron-20180520 cron-20180527 cron-20180603
~~~
#### 3. crontab输出重定向
如果crontab不重定向输出,并且crontab所执⾏的命令有输出内容的话,是⼀件⾮常危险的事情。因为该输出内容会以邮件的形式发送给⽤户,内容存储在邮件⽂件
/var/spool/mail/$user
如果命令执⾏⽐较频繁(如每分钟⼀次),或者命令输出内容较多,会使这个邮件⽂件不断追加内容,⽂件越来越⼤。⽽邮件⽂件⼀般存放在根分区,根分区⼀般相对较⼩,所以会造成根分区写满⽽⽆法登录服务器。
所以在添加crontab命令时,⽆论命令是否有输出,最好都加上输出重定向到⽂件或者/dev/null中。如下
~~~
*/5 * * * * /root/XXXX.sh &>/dev/null 2>&1
~~~
`/dev/null` 代表空设备⽂件
> 代表重定向到哪⾥,例如:echo "123" > /
1 表⽰stdout标准输出,系统默认值是1,所以">/dev/null"等同于"1>/dev/null"
2 表⽰stderr标准错误
& 表⽰等同于的意思,2>&1,表⽰2的输出重定向等同于1
那么>/dev/null 2>&1的意思就是:
标准输出重定向到空设备⽂件,也就是不输出任何信息到终端,标准错误输出重定向等同于标准输出,因为之前标准输出已经重定向到了空设备⽂件,所以标准错误输出也重定向到空设备⽂件。
#### crontab⽇志每天⽣成⼀个⽂件
crontab.shlinux重定向
~~~
#!/bin/bash
~/cronLog/cron_`date +\%Y\%m\%d`.log
date >> ~/cronLog/cron_`date +\%Y\%m\%d`.log
echo -e >> ~/cronLog/cron_`date +\%Y\%m\%d`.log
~~~
⽣成⽂件名为:cron_20161108.log crontab 使⽤⽇期时间命名重定向⽂件
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论