我有这个问题吗?
我正在午夜时分安排一个cron工作
0 0 * * * /usr/bin/php myscript.php
该脚本设置为以MySQL时间戳格式定义前一天的日期。
$midnightyesterday2 = (new DateTime())->setTime(0, 0);
$midnightyesterday2->modify('-1 day');
$midnightyesterday = $midnightyesterday2->format("Y-m-d H:i:s");
回声输出:
2017-04-08 00:00:00
$endofdayyesterday2 = (new DateTime())->setTime(23, 59, 59);
$endofdayyesterday2->modify('-1 day');
$endofdayyesterday = $endofdayyesterday2->format("Y-m-d H:i:s");
回声输出:
2017-04-08 23:59:59
显然这个示例输出工作正常,因为我在15:22:00这样做。
如果脚本出于某种原因提前一点点,那么在午夜时分设置一个cron工作可能会导致冲突,这只是一种偏执。
有没有更好的方法来确保昨天的日期,脚本设置为在午夜运行?
我需要它在午夜时分运行,因为脚本基于我的回声暗示的MySQL lastmodified
时间戳,甚至在12:01运行它可能会留下一些额外的行在那一分钟被添加。
请尝试以下代码,以确切的小时数获取昨天的开始和结束日期。
date("Y-m-d H:i:s", strtotime("yesterday")); // 2018-09-18 00:00:00
date("Y-m-d H:i:s", strtotime("today 1 sec ago")); // 2018-09-18 23:59:59
我的解决方案(评论中提到的那种方式)是执行以下操作:
请记住,脚本设置为在午夜(00:00:00)运行。
所以我正在设置一个新的DateTime
对象,增加12个小时。 (12:00:00)
然后在提前12小时后,使用setTime
将时间设置为00:00:00。
然后再次使用DateTime的modify
减去24小时。
$midnightyesterday2 = new DateTime();
$midnightyesterday2->modify('+12 hour');
$midnightyesterday2->setTime(0, 0);
$midnightyesterday2->modify('-24 hour');
$midnightyesterday = $midnightyesterday2->format("Y-m-d H:i:s");
echo $midnightyesterday;
2017-04-08 00:00:00
与获得昨天结束的结果相同
$endofdayyesterday2 = new DateTime();
$endofdayyesterday2->modify('+12 hour');
$endofdayyesterday2->setTime(23, 59, 59);
$endofdayyesterday2->modify('-24 hour');
$endofdayyesterday = $endofdayyesterday2->format("Y-m-d H:i:s");
echo $endofdayyesterday;
2017-04-08 23:59:59
我不是说这是最好的方法,这个想法只是来找我。但似乎可能会为我正在尝试的事情添加一种故障安全措施。
如果某人有更好或更合适的解决方案,我会暂时保持这种状态。