用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,之前使用这个方法导数据的时候也出现过内存泄露的问题,当时找了半天没找到问题在哪里,估计就是如此,回家再试试。
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.