将crontab执行的输出,重定向到加了日期作为文件名的日志中,日期字符串的%必须要被转义!

问题提出

如题,原本需要手动执行的任务,我现在想用crontab周期性执行,具体情况为每一天固定时间执行一次。

以下是我原本代码(不用crontab,手动执行)

$ time bash taskrunner.sh >log/`date +"%Y%m%d"`_formal.log 2>&1

这是个很好理解的代码。我运行taskrunner.sh脚本,然后将脚本的"标准输出"重定向到20190813_formal.log文件中(对今天而言),然后将"标准错误"也重定向到标准输出中。这个直接在shell中可以运行。

不过,一旦你将这行命令通过crontab -e编辑到crontab脚本中,如下所示:

*/5 * * * * time bash tashrunner.sh >log/`date +"%Y%m%d"`_formal.log 2>&1

那么结果就是啥也没发生。。。crontab并没有将你的程序每隔5分钟执行一次,甚至20190813_formal.log文件都没有生成。

So,why??

问题解决

如果你确定你的日志文件和可执行脚本的路径没有问题(在crontab中最好都使用绝对路径),那么问题就是出在字符的转义上。crontab文件中无法理解%的含义,因而需要将%转义。所以上面的crontab命令应该写成下面这样:

*/5 * * * * time bash tashrunner.sh >log/`date +"\%Y\%m\%d"`_formal.log 2>&1

PS,反引号中的内容:'date'和后面的'+.....'之间,要有一个空格,否则date命令无法执行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_illusion_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值