Dev*_*xon 3 linux bash cron date
我正在使用 cron 将文件写入由 bash 脚本运行的日志中。对 cron 的调用如下所示:
*/25 * * * * bash script.sh > "/var/log/$(date +%Y-%m-%d_%H:%M).log"
Run Code Online (Sandbox Code Playgroud)
但是当我检查 crontab 时,它记录为
*/25 * * * * bash script.sh > "/var/log/$(date +).log"
Run Code Online (Sandbox Code Playgroud)
并且它从不写入日志文件。我需要更改什么才能让 cron 写入日期吗?
这是一个转义变量的问题:
* * * * * /usr/bin/touch /tmp/$(date +\%Y:\%m).log
# ^ ^
Run Code Online (Sandbox Code Playgroud)
对我有用。
从man 5 crontab:
命令中的百分号 (%),除非用反斜杠 (\) 转义,否则将更改为换行符,并且第一个 % 之后的所有数据都将作为标准输入发送到命令。
所以
*/25 * * * * /bin/bash script.sh > "/var/log/$(date +\%Y-\%m-\%d_\%H:\%M).log"
# ^ ^ ^ ^ ^
Run Code Online (Sandbox Code Playgroud)
应该管用。
请注意,我使用的/bin/bash不仅仅是bash.
| 归档时间: |
|
| 查看次数: |
812 次 |
| 最近记录: |