刚刚了解到Laravel内部使用nikic phpparser。
我修改了我的代码,以发送电子邮件的条件之一&它开始死亡。
PHP日志显示如下:
[p>[Sat Oct 03 21:18:23 2015] [error] [client xx.xx.xx.]PHP致命的错误:允许的内存大小为33554432字节耗尽(尝试)分配1048576字节)/home/yyyy/public_html/供应商/nikic/php-parser/lib/PHPParser/NodeTraverser.php在第66行,引用: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);
}
);
如何解决这个问题?
您的内存限制非常低。默认情况下,IIRC PHP限制从128M开始。当解析器运行时,它为代码的每个部分构建一个节点。没有什么是排除在外的,也没有简单的修复方法。
内存比以往任何时候都便宜,这个问题不太可能被修复,因为即将到来的PHP7。也许可以尝试一下,因为它可能有更小的内存占用。