【问题标题】:Laravel 4 using nikic phpparser : Going out of memory when sending emailLaravel 4 使用 nikic phpparser:发送电子邮件时内存不足
【发布时间】:2015-10-03 22:03:58
【问题描述】:

刚刚了解到 Laravel 在内部使用 nikic phpparser。

我修改了我的代码以在其中一种情况下发送电子邮件,它开始死机。
PHP 日志显示了这一点:

[2015 年 10 月 3 日星期六 21:18:23] [错误] [客户端 xx.xx.xx.xx] PHP 致命 错误:允许的内存大小为 33554432 字节已用尽(试图 分配 1048576 字节)在 /home/yyyy/public_html/vendor/nikic/php-parser/lib/PHPParser/NodeTraverser.php 第66行,referer:http://yyyy.com/home

我暂时增加了内存来解决这个问题。
但是,我想摆脱创可贴。
我看到 NodeTraverser 函数正在执行克隆,这会导致问题吗:

   protected function traverseNode(PHPParser_Node $node)
   {

    ini_set('memory_limit', '64M'); // temporary fix
    $node = clone $node;

    foreach ($node->getSubNodeNames() as $name) {
        $subNode =& $node->$name;

        if (is_array($subNode)) {
            $subNode = $this->traverseArray($subNode);
        } elseif ($subNode instanceof PHPParser_Node) {
            foreach ($this->visitors as $visitor) {
                if (null !== $return = $visitor->enterNode($subNode)) {
                    $subNode = $return;
                }
            }

            $subNode = $this->traverseNode($subNode);

            foreach ($this->visitors as $visitor) {
                if (null !== $return = $visitor->leaveNode($subNode)) {
                    $subNode = $return;
                }
            }
        }
    }

    return $node;
}

这就是我发送电子邮件的方式。这与其他任何地方没有什么不同,因此我怀疑这会导致问题:

                 $this->mailer->queue('emails.forreg',
                        [
                            'toName' =>  $toEmailName,
                            'fromName' =>  $user->username,
                            'site_name' => \Config::get('site_title')
                        ],
                        function($mail) use($toEmailAddress, $user, $subject_to_send, $toEmailName)
                        {
                            $mail->to($toEmailAddress, $toEmailName)
                                ->subject($subject_to_send)
                                ->from('xxx@yyy.com', $user->username);
                        }
                    );

关于如何解决这个问题的任何想法?

【问题讨论】:

  • 我现在看到问题出现在 phpparser 文件的多个位置。

标签: laravel out-of-memory php-parser


【解决方案1】:

你只是有一个极低的内存限制。 IIRC PHP 限制默认从 128M 开始。当解析器通过它时,它会为代码的每个部分建立一个节点。没有任何东西被排除在外,也没有简单的热修复。

今天的内存比以往任何时候都便宜,而且由于即将推出的 PHP7,这个问题不太可能得到解决。也许可以尝试一下,因为无论如何它可能会占用更小的内存。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2014-08-19
    • 2015-12-20
    • 1970-01-01
    • 2022-08-13
    • 2019-12-02
    • 1970-01-01
    • 1970-01-01
    • 2011-01-08
    相关资源
    最近更新 更多