Laravel 4使用nikic phpparser:发送电子邮件时内存不足

问题描述:

刚刚得知Laravel在内部使用nikic phpparser。Laravel 4使用nikic phpparser:发送电子邮件时内存不足

我修改了我的代码,发送电子邮件的条件之一&它开始死亡。
PHP的日志显示此:

[Sat Oct 03 21:18:23 2015] [error] [client xx.xx.xx.xx] PHP Fatal error: Allowed memory size of 33554432 bytes exhausted (tried to allocate 1048576 bytes) in /home/yyyy/public_html/vendor/nikic/php-parser/lib/PHPParser/NodeTraverser.php on line 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('[email protected]', $user->username); 
         } 
        ); 

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

+0

我现在看到问题发生在phpparser文件的多个地方。 – PlanetUnknown

您只是具有极低的内存限制。 IIRC默认情况下,PHP限制从128M开始。当解析器经历它为代码的每个单独部分建立一个节点时。没有任何东西被排除在外,没有简单的修复方法。

内存比以往任何时候都便宜,而且这个问题不太可能因为即将到来的PHP7而被解决。不妨试试看,因为无论如何它可能会有更小的内存占用。