linux cron记录时间,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" > /home/123.txt

1 表示stdout标准输出,系统默认值是1,所以">/dev/null"等同于"1>/dev/null"

2 表示stderr标准错误

& 表示等同于的意思,2>&1,表示2的输出重定向等同于1

那么>/dev/null 2>&1的意思就是:

标准输出重定向到空设备文件,也就是不输出任何信息到终端,标准错误输出重定向等同于标准输出,因为之前标准输出已经重定向到了空设备文件,所以标准错误输出也重定向到空设备文件。

#### crontab日志每天生成一个文件

crontab.sh

~~~

#!/bin/bash

curl http://task.bluelive.me/api/crontab >> ~/cronLog/cron_`date +\%Y\%m\%d`.log

~/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 使用日期时间命名重定向文件

https://blog.csdn.net/fdipzone/article/details/51778543

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值