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?
Ora vedo che il problema si verifica in più punti nei file phpparser. – PlanetUnknown