我正在使用 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 写日期吗?
这是转义变量的问题:
* * * * * /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
.