首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在Symfony 1.4中运行任务时使用更少的内存?

如何在Symfony 1.4中运行任务时使用更少的内存?
EN

Stack Overflow用户
提问于 2010-03-17 23:05:44
回答 8查看 5.2K关注 0票数 17

我使用Symfony 1.4和Doctrine。

到目前为止,我在Symfony上运行任务没有任何问题。但现在我必须导入大量数据并将它们保存在数据库中,我得到了臭名昭著的

“致命错误:允许的XXXX字节内存大小已耗尽”

在这个导入过程中,我只创建新对象,设置一些字段并保存它们。

我很确定这与我在保存数据时创建的对象数量有关。不过,取消设置这些对象并不会产生任何影响。

在Symfony中是否有限制内存使用的最佳实践?

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2010-03-17 23:13:09

我遇到过这种情况,我发现有几种技术对Doctrine的广泛内存使用真的很有帮助。

1:在可能的情况下,将Doctrine查询结果简化为数组。你可以这样做,例如:

代码语言:javascript
复制
$query = self::createQuery("q")->
  ...
  ->setHydrationMode(Doctrine::HYDRATE_ARRAY)
  ->execute();

这迫使Doctrine不创建大对象,而是将其缩减为数组。显然要记住,如果你这样做,你会失去调用方法等的能力,所以只有当你用它来读取字段值等时,这才是好的。

2:执行后释放结果。Doctrine文档的一个小区域记录了这一点,但它确实帮助了我正在使用的导入任务:

代码语言:javascript
复制
$query->free();

就这样。你也可以在你创建的对象上这样做,例如$myObj->free();,这会强制Doctrine删除它创建的所有循环引用。请注意,从PHP5.3开始,通过PHP作用域或unset()删除对象时,循环引用会自动释放,但在此之前,您需要自己执行此操作。

在使用变量后取消设置变量也会有所帮助,尽管要与上面提到的free()方法结合使用,否则unset()不会清除循环引用。

票数 11
EN

Stack Overflow用户

发布于 2011-07-11 19:40:58

试试这个:

代码语言:javascript
复制
Doctrine_Manager::connection()->setAttribute(Doctrine_Core::ATTR_AUTO_FREE_QUERY_OBJECTS, true );

如上所述

php/symfony/doctrine memory leak?

乔丹·费尔德斯坦的回答不是我的。

票数 4
EN

Stack Overflow用户

发布于 2012-04-27 10:42:38

减少任务中使用的内存量的另一个提示是禁用查询探查器。大量的查询往往会使任务使用越来越多的内存。

为此,通过添加以下行,在database.yml配置文件中创建一个新的任务环境:

代码语言:javascript
复制
task:
  doctrine:
    class: sfDoctrineDatabase
    param:
      profiler: false

然后设置你的任务在“任务”环境中运行。如果您的查询处于循环中,它应该有助于保持内存使用的稳定性。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2463337

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档