2015-10-03 6 views
6

Ho appena appreso che Laravel utilizza internamente il nikic phpparser.Laravel 4 con nikic phpparser: esaurimento della memoria durante l'invio di e-mail

Ho modificato il mio codice per l'invio di e-mail su una delle condizioni & ha iniziato a morire.
I registri PHP hanno mostrato questo:

[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

temporaneamente ho aumentato la memoria per risolvere il problema.
Ma, voglio spostarmi dal cerotto.
vedo che la funzione NodeTraverser sta facendo un clone, vorrei che causare il problema:

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; 
} 

Questo è come mi sto inviando l'email. Questo non è diverso che altrove, quindi dubito che questo causerebbe un problema:

    $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); 
         } 
        ); 

Tutte le idee su come risolvere questo?

+0

Ora vedo che il problema si verifica in più punti nei file phpparser. – PlanetUnknown

risposta

0

Hai semplicemente un limite di memoria estremamente basso. Il limite di IIRC PHP inizia a 128 M per un valore predefinito. Quando passa il parser, crea un nodo per ogni singola parte del codice. Nulla è escluso e non c'è una soluzione rapida facile.

La memoria è più economica che mai oggi e questo problema è improbabile che venga risolto a causa dell'imminente PHP7. Forse provalo perché è probabile che abbia comunque un minor ingombro di memoria.