用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-02-27 20:59:52 +08:00
https://bugs.php.net/ 给报一个?
|
2
thankyourtender 2015-02-28 09:58:42 +08:00
用原生的MySQL查询测试一下?
|
3
freefcw OP |
4
kn007 2015-02-28 15:11:54 +08:00
期待最终结果,目前用的也是5.5
|
5
kimmykuang 2015-02-28 16:05:12 +08:00
mark下,mac用brew装的就是5.5吧
|
6
Jaylee 2015-02-28 18:21:01 +08:00
@kimmykuang 我也是用brew装的 5.6.12
|