本节内容:

phpQuery占用内存过多的问题

phpQuery是一个用php实现的类似jquery的开源项目,可以在服务器端以jQuery的语法形式解析网页元素。

相对于正则或其它方式匹配网页方式,phpQuery使用起来要方便的多。

在使用phpQuery采集网页时,遇到一个问题:在处理大量网页之后,phpQuery占用的内存数量非常惊人(很快就超过了1G),

例如:

复制代码 代码示例:

while (true) {

phpQuery::newDocumentFile($htmlFile);

// 处理网页元素...

echo memory_get_usage() . "\n";

}

注意:以上代码会用光你机器的内存。

问题分析:

phpQuery在每处理一个网页就会产生一个DOMDocumentWrapper 对象,而每个DOMDocumentWrapper 对象会被保存在静态成员$documents中(phpQuery::createDocumentWrapper中),这个变量是一个数组,每解析一个网页数组元素就增加一个。

phpQuery::$documents[$wrapper->id] = $wrapper;

解决方法:

每次解析完一个网页,把phpQuery::$documents置空即可。

例如:

复制代码 代码示例:

while (true) {

phpQuery::newDocumentFile($htmlFile);

// 处理网页元素...

phpQuery::$documents = array();

echo memory_get_usage() . "\n";

}

如此,内存占用便稳定下来了。

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐