使用Symfony + Doctrine在PHP中发生内存泄漏

时间:2010-06-04 10:15:54

标签: php memory-leaks symfony1 doctrine

我正在使用PHP和Symfony框架(使用Doctrine作为我的ORM)来构建一个爬行某些网站的蜘蛛。

我的问题是以下代码生成内存泄漏:

$q = $this -> createQuery('Product p');

if($store) {
    $q
        -> andWhere('p.store_id = ?', $store -> getId())
        -> limit(1);
}

$q -> andWhere('p.name = ?', $name);

$data = $q -> execute();
$q -> free(true);
$data -> free(true);
return NULL;

此代码位于Doctrine_Table的子类中。如果我注释掉执行部分(当然还有$data -> free(true)),泄漏就会停止。这使我得出的结论是导致泄漏的Doctrine_Collection

4 个答案:

答案 0 :(得分:5)

我通过释放取消数据来解决我的Doctrine内存泄漏问题,你试过吗?

// ...
$data->free(true) ;
unset($data) ;
// ...

答案 1 :(得分:1)

您使用的是哪个版本的PHP?如果它是< 5.3它可能与'recursive references leak memory'错误有关。

您也可以尝试调用Doctrine_Manager::connection()->clear(),这应该清理连接并删除身份映射条目

答案 2 :(得分:0)

您是否应该使用addWhere而不是andWhere?另外我认为应该在声明的最后添加一个限制,尝试:

$q = $this -> createQuery('Product p') -> where('p.name = ?', $name);

 if($store) {
$q
    -> addWhere('p.store_id = ?', $store -> getId())
    -> limit(1);
 }

 $data = $q -> execute();
 $q -> free(true);
 $data -> free(true);
return NULL;

答案 3 :(得分:0)

我正在使用连续运行的CLI命令遇到同样的问题。在花了很多时间来解决这个问题之后,事实证明在prod模式下运行我的命令实际上解决了这个问题:

app/console my:custom:command --env=prod