解决phpQuery占用内存过多的问题
发布时间:2017-04-14 编辑:www.jquerycn.cn
本文介绍下,使用phpQuery时占用内存过多问题的解决方法,有遇到类似问题的朋友,可以参考下。
本节内容:
phpQuery占用内存过多的问题
phpQuery是一个用php实现的类似jquery的开源项目,可以在服务器端以jQuery的语法形式解析网页元素。
相对于正则或其它方式匹配网页方式,phpQuery使用起来要方便的多。
在使用phpQuery采集网页时,遇到一个问题:在处理大量网页之后,phpQuery占用的内存数量非常惊人(很快就超过了1G),
例如:
复制代码 代码示例:
<?php
while (true) {
phpQuery::newDocumentFile($htmlFile);
// 处理网页元素...
echo memory_get_usage() . "\n";
}
while (true) {
phpQuery::newDocumentFile($htmlFile);
// 处理网页元素...
echo memory_get_usage() . "\n";
}
注意:以上代码会用光你机器的内存。
问题分析:
phpQuery在每处理一个网页就会产生一个DOMDocumentWrapper 对象,而每个DOMDocumentWrapper 对象会被保存在静态成员$documents中(phpQuery::createDocumentWrapper中),这个变量是一个数组,每解析一个网页数组元素就增加一个。
phpQuery::$documents[$wrapper->id] = $wrapper;
解决方法:
每次解析完一个网页,把phpQuery::$documents置空即可。
例如:
复制代码 代码示例:
<?php
while (true) {
phpQuery::newDocumentFile($htmlFile);
// 处理网页元素...
phpQuery::$documents = array();
echo memory_get_usage() . "\n";
}
while (true) {
phpQuery::newDocumentFile($htmlFile);
// 处理网页元素...
phpQuery::$documents = array();
echo memory_get_usage() . "\n";
}
如此,内存占用便稳定下来了。
您可能感兴趣的文章:
上一篇:PHP静态变量作为缓存的方法
下一篇:php sitemap文件生成器代码
[关闭]