gpt4 book ai didi

php - cron 如何根据日期输出到新的日志文件?

转载 作者:行者123 更新时间:2023-12-05 09:22:21 26 4
gpt4 key购买 nike

我想将 cron 输出记录到一个日期文件 — /tmp/log/cron-2014-12-17.log

$ mkdir /tmp/log
$ chmod 777 /tmp/log
$ ls -lah /tmp/log
drwxrwxrwx 2 root root 4.0K Dec 17 21:51 .

Cron(通过 root 用户)

* * * * * /usr/bin/php /path/to/script.php > /tmp/log/cron-$(date "+%F").log 2>&1

/tmp/log 每分钟后保持为空。

如果我从命令行手动运行脚本,则会创建一个日志文件,并且输出符合预期。

// Running it manually as a CLI works fine, but not as a cron
$ /usr/bin/php /path/to/script.php > /tmp/log/cron-$(date "+%F").log 2>&1

此外,如果我创建一个文件并对其进行 chmod 777,cron 将输出写入这个创建的文件。它只是不会即时创建一个。

// Let's create it first
$ touch /tmp/log/cron.log
$ chmod 777 /tmp/log/cron.log
// wait for the next minute...
$ tail -f /tmp/log/cron.log
output... output... output...

但这不适用于像 /tmp/log/cron-2014-12-17.log 这样的动态名称。

我错过了什么?

最佳答案

这将解决您的问题:

0 0 * * * /some/path/to/a/file.php >> /tmp/log/cron-`date +\%F`.log 2>&1

关于php - cron 如何根据日期输出到新的日志文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27539083/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com