php5.5.9 存在内存泄露

2015-02-27 20:53:30 +08:00
 freefcw

用Laravel的Command导入数据,随着内存直线飙升,最后OOM。用xhprof找内存都用在哪里了,发现都消耗在了闭包中,具体位置在Illuminate\Database\Connection::runQueryCallback函数中。

写函数测试:

public function testDB()
{
    for($i = 0; $i < 1000000; $i ++)
    {
        if ( $i % 100 == 0)
            $this->comment($i);
        \DB::connection()->select('select * from albums limit 1');
    }
}

运行也是内存随执行次数成正比,结果和分析一致。

升级到5.6.6以后,就没有再出现内存暴涨的问题了,估计是php5.5中对闭包处理不够好

印象中homebrew带的也是5.5,之前使用这个方法导数据的时候也出现过内存泄露的问题,当时找了半天没找到问题在哪里,估计就是如此,回家再试试。

4323 次点击
所在节点    PHP
6 条回复
mactalk
2015-02-27 20:59:52 +08:00
https://bugs.php.net/ 给报一个?
thankyourtender
2015-02-28 09:58:42 +08:00
用原生的MySQL查询测试一下?
freefcw
2015-02-28 13:04:59 +08:00
@mactalk 昨天破坏了现场,没有办法复现了,估计可能是什么其他地方有问题。找个时间再看看


@thankyourtender 嗯,谢谢。
kn007
2015-02-28 15:11:54 +08:00
期待最终结果,目前用的也是5.5
kimmykuang
2015-02-28 16:05:12 +08:00
mark下,mac用brew装的就是5.5吧
Jaylee
2015-02-28 18:21:01 +08:00
@kimmykuang 我也是用brew装的 5.6.12

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/173326

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX