1

我们有一个 Cron 脚本,它可以检测 - 如果某些用户被踢出我们的应用程序。如果特定值为 1,我们可以检测到这一点 - 但在流中,没有设置新条目。脚本每小时运行一次。大多数未检测到。但自 2012-10-31 23:59:03 以来,每个用户都被检测到。如果我在本地机器上运行脚本,甚至在 cron 运行的同一台机器上运行脚本。一切都得到了应有的处理。首先,我们的脚本:

require_once ('cron_init.php');
ini_set('date.timezone', 'Europe/Berlin');
ini_set('max_execution_time', 30);
ini_set('memory_limit', -1);
error_reporting(E_ALL);
ini_set("display_errors", 1);

Zend_Date::setOptions(array('fix_dst' => true));

    $userinfos = new Repricing_Dbservices_Userinfos();
    $users = $userinfos->getUsersForRepricing();

    $repricingstream = new Repricing_Dbservices_Repricingstream();
    $error = new Repricing_Dbservices_Error();

if($users!==false AND count($users)>0){

    $counter = 0;
    $errCounter = 0;
    $jetzt = new Zend_Date();
    $jetzt->setTimezone('Europe/Berlin');
    $jetzt = $jetzt->get(Zend_Date::TIMESTAMP);

    foreach($users as $user){
        $stream = $repricingstream->getStreamLimit($user);

        $last = new Zend_Date($stream);
        $last->setTimezone('Europe/Berlin');
        $last = $last->get(Zend_Date::TIMESTAMP);

        $diff = (($jetzt-$last)/60);

        $error->setError(1, 'DIED', $diff, $user);

        if($diff > 50 ){
            $errCounter++;
            $userinfos->setUserFree($user);
            $error->setError(1, 'DIED', 'ANSTOSSEN', $user);
        }

        $counter++;
    }
    $error->setError(1, $errCounter, 'ANSTOSSEN_ALL', 'ALL');
}

通常$diff >= 0 AND $diff <= 4,但是,我们发现,它$diff总是大约381595. 如果我们将它从 cron$diff中运行出来,那么它应该是这样的。我们还发现,$jetzt现在(应该如此)只是$last晚得多。381595之后。但那不应该。最后的流日期是完全正常的。我们无法理解这种行为。Zend_Date 与 cron。Bevor2012-10-21 23:59:03脚本运行 2 周,因为它应该。我们无法解释,怎么会。你能?

4

1 回答 1

1

考虑一下:

$right = new Zend_Date('2012-11-01 12:12:12', Zend_Date::ISO_8601);
var_dump( $right->getIso() );        // 2012-11-01T12:12:12+00:00
var_dump( $right->getTimestamp() );  // 1351771932

$wrong = new Zend_Date('2012-11-01 12:12:12', null, 'en_US');
var_dump( $wrong->getIso() );        // 2012-01-11T12:12:12+00:00
var_dump( $wrong->getTimestamp() );  // 1326283932

现在是真正的怪异部分:在我的 PC 上,这是默认的第二个行为 - 即,当 Zend_Date 构造函数没有额外的参数时。

关键是,Zend_Date 有点……在尝试解析日期时间字符串时太有帮助了。例如,它考虑了语言环境 - 但服务器和客户端的语言环境!如果无法在此语言环境的规则中解析字符串,它会默默地放弃 - 并尝试使用另一个规则。

这就是为什么2012-10-29被解析为October, 29尽管语言环境建议,因为没有第 29 个月) - 但2012-11-01变成January, 11- 并且把你的脚本搞砸了。)

于 2012-11-02T16:14:11.973 回答