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);
}
);
上的任何想法如何解决这个问题?
答
您只是具有极低的内存限制。 IIRC默认情况下,PHP限制从128M开始。当解析器经历它为代码的每个单独部分建立一个节点时。没有任何东西被排除在外,没有简单的修复方法。
内存比以往任何时候都便宜,而且这个问题不太可能因为即将到来的PHP7而被解决。不妨试试看,因为无论如何它可能会有更小的内存占用。
我现在看到问题发生在phpparser文件的多个地方。 – PlanetUnknown