cron 作业使用哪个时区?

Edw*_*ard 26 linux php time timezone

我猜我的 PHP 时间和服务器时间之间存在差异。

当我在 PHP 中检查当前时间时,它显示正在使用 MST。但是,cron 作业没有在正确的时间运行。

如何检查服务器本身使用的时区,而不是 PHP 设置使用的时区?

imv*_*jal 28

Cron 作业使用服务器的定义时区(默认为 UTC),您可以通过date在终端中键入命令来检查。

所有国家/地区时区都在/usr/share/zoneinfo目录中定义:

cd  /usr/share/zoneinfo/
Run Code Online (Sandbox Code Playgroud)

当您 cd 进入此目录时,您将看到不同国家的名称及其时区。

更改服务器时区的命令。

sudo ln -sf /usr/share/zoneinfo/America/Los_Angeles /etc/localtime
Run Code Online (Sandbox Code Playgroud)

如果您住在美国 > 洛杉矶,您可以使用上述命令更改时区。根据您的要求更改国家和州。


检查日期和时间的命令:

 date
Run Code Online (Sandbox Code Playgroud)

从命令行设置时间和日期:

date -s "19 APR 2012 11:14:00"
Run Code Online (Sandbox Code Playgroud)

  • 在命令行运行“date”并不是检查“cron”所看到的日期的可靠方法,因为您可能在 shell 中设置了“TZ”。运行 env -u TZ date 会显示系统默认时区的日期,这样会好一点。但“cron”也可能有自己的“TZ”集,您可以通过查看“/proc/$(</var/run/crond.pid)/environ”来检查。 (4认同)
  • 设置时区后需要“sudo service cron restart” (2认同)

小智 8

虽然接受的答案是正确的,但我想对验证进行更正。

接受的答案表示您可以通过在终端中输入日期来验证系统时间。

当我输入日期时,它会告诉我所在时区的时间,即中部时间。我尝试了与 root 相同的命令,它总是返回我的时区。当我检查系统日志时,它还显示了我预期作业执行的时间。

然后我打开 crontab,它会在未来某个时间在系统日志中注册一个条目。这就是我验证服务器是否使用 UTC 时间的方法。但要指出的是,至少在我的例子中,使用命令 date 并不能验证 cron 执行的时区。


rui*_*ief 7

除非您事先知道cron 正在运行的时区,否则唯一可靠的解决方案是凭经验进行检查。否则,您可能只是检查当前 shell 环境的时区,或者检查可能与 cron 不同的系统范围时区。

这是一个 bash 语句,告诉你 cron 看到的时区:

env -i $(cat /proc/$(</var/run/crond.pid)/environ|xargs -0 echo) date +%Z

此命令创建一个与正在运行的 cron 守护程序相同的环境,然后date在该环境中运行。

  • 这对于测试其他命令是否也能工作并调试它们非常有用。**谢谢你!** (2认同)

小智 6

如果你有很多用户,有很多 crontab 并且他们有不同的时区要求,你不能只改变系统时区。

但是您仍然可以设置一个特定的时区,仅用于特定 crontab 中的 cron 作业,在 crontab 的开头设置变量 CRON_TZ。

例如

#@IgnoreInspection BashAddShebang
SHELL=/usr/bin/bash
CRON_TZ=UTC
PROJECT_DIR=/home/MY_USER/MY_PROJECT

40 06 * * 1-5 $PROJECT_DIR/prod/ingest.sh >> $PROJECT_DIR/logs/ingest_cron.out 2>> $PROJECT_DIR/logs/ingest_cron.err
Run Code Online (Sandbox Code Playgroud)

  • 看来这不会影响 cron 作业的执行时间。 (5认同)