Pla*_*own 6 out-of-memory php-parser laravel
刚刚得知Laravel内部使用了nikic phpparser.
我修改了我的代码,以便在其中一个条件下发送电子邮件并开始死亡.
PHP日志显示了这个:
[Sat Oct 03 21:18:23 2015] [错误] [client xx.xx.xx.xx] PHP致命错误:/ home/yyyy/public_html /中允许的内存大小为33554432字节(尝试分配1048576字节)供应商/ nikic/PHP的解析器/ 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;
}
Run Code Online (Sandbox Code Playgroud)
这就是我发送电子邮件的方式.这与其他地方没有什么不同,因此我怀疑这会导致一个问题:
$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);
}
);
Run Code Online (Sandbox Code Playgroud)
关于如何解决这个问题的任何想法?
您的内存限制非常低。IIRC PHP 限制默认从 128M 开始。当解析器执行时,它会为代码的每个部分构建一个节点。没有什么是被排除的,并且没有简单的修补程序。
如今内存比以往任何时候都便宜,而且由于即将推出的 PHP7,这个问题不太可能得到解决。也许可以尝试一下,因为无论如何它的内存占用可能会更小。
| 归档时间: |
|
| 查看次数: |
167 次 |
| 最近记录: |