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