2

我正在使用 cron 将文件写入由 bash 脚本运行的日志。对 cron 的调用如下所示:

*/25 * * * * bash script.sh > "/var/log/$(date +%Y-%m-%d_%H:%M).log"

但是当我检查 crontab 它记录为

*/25 * * * * bash script.sh > "/var/log/$(date +).log"

它从不写入日志文件。我需要改变什么来让 cron 写日期吗?

4

1 回答 1

5

这是转义变量的问题:

* * * * * /usr/bin/touch /tmp/$(date +\%Y:\%m).log
#                                      ^   ^

对我有用。

来自man 5 crontab

命令中的百分号 (%),除非用反斜杠 (\) 转义,否则将更改为换行符,第一个 % 之后的所有数据将作为标准输入发送到命令。

所以

*/25 * * * * /bin/bash script.sh > "/var/log/$(date +\%Y-\%m-\%d_\%H:\%M).log"
#                                                    ^    ^   ^   ^   ^

应该管用。

请注意,我使用/bin/bash的不仅仅是bash.

于 2013-04-26T14:21:25.437 回答