我正在使用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
。
答案 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