我使用Symfony 1.4和Doctrine。
到目前为止,我在Symfony上运行任务没有任何问题。但现在我必须导入大量数据并将它们保存在数据库中,我得到了臭名昭著的
“致命错误:允许的XXXX字节内存大小已耗尽”
在这个导入过程中,我只创建新对象,设置一些字段并保存它们。
我很确定这与我在保存数据时创建的对象数量有关。不过,取消设置这些对象并不会产生任何影响。
在Symfony中是否有限制内存使用的最佳实践?
发布于 2010-03-17 23:13:09
我遇到过这种情况,我发现有几种技术对Doctrine的广泛内存使用真的很有帮助。
1:在可能的情况下,将Doctrine查询结果简化为数组。你可以这样做,例如:
$query = self::createQuery("q")->
...
->setHydrationMode(Doctrine::HYDRATE_ARRAY)
->execute();
这迫使Doctrine不创建大对象,而是将其缩减为数组。显然要记住,如果你这样做,你会失去调用方法等的能力,所以只有当你用它来读取字段值等时,这才是好的。
2:执行后释放结果。Doctrine文档的一个小区域记录了这一点,但它确实帮助了我正在使用的导入任务:
$query->free();
就这样。你也可以在你创建的对象上这样做,例如$myObj->free();
,这会强制Doctrine删除它创建的所有循环引用。请注意,从PHP5.3开始,通过PHP作用域或unset()
删除对象时,循环引用会自动释放,但在此之前,您需要自己执行此操作。
在使用变量后取消设置变量也会有所帮助,尽管要与上面提到的free()
方法结合使用,否则unset()
不会清除循环引用。
发布于 2011-07-11 19:40:58
试试这个:
Doctrine_Manager::connection()->setAttribute(Doctrine_Core::ATTR_AUTO_FREE_QUERY_OBJECTS, true );
如上所述
php/symfony/doctrine memory leak?
乔丹·费尔德斯坦的回答不是我的。
发布于 2012-04-27 10:42:38
减少任务中使用的内存量的另一个提示是禁用查询探查器。大量的查询往往会使任务使用越来越多的内存。
为此,通过添加以下行,在database.yml配置文件中创建一个新的任务环境:
task:
doctrine:
class: sfDoctrineDatabase
param:
profiler: false
然后设置你的任务在“任务”环境中运行。如果您的查询处于循环中,它应该有助于保持内存使用的稳定性。
https://stackoverflow.com/questions/2463337
复制相似问题