用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,之前使用这个方法导数据的时候也出现过内存泄露的问题,当时找了半天没找到问题在哪里,估计就是如此,回家再试试。
|  |      1mactalk      2015-02-27 20:59:52 +08:00 https://bugs.php.net/ 给报一个? | 
|      2thankyourtender      2015-02-28 09:58:42 +08:00 用原生的MySQL查询测试一下? | 
|  |      3freefcw OP | 
|  |      4kn007      2015-02-28 15:11:54 +08:00 期待最终结果,目前用的也是5.5 | 
|      5kimmykuang      2015-02-28 16:05:12 +08:00 mark下,mac用brew装的就是5.5吧 | 
|  |      6Jaylee      2015-02-28 18:21:01 +08:00 @kimmykuang 我也是用brew装的  5.6.12 |