phpQuery占用内存过多的处理方法
2015-01-24信息快讯网
本文解决phpQuery占用内存过多的问题
phpQuery是一个用php实现的类似jQuery的开源项目,可以在服务器端以jQuery的语法形式解析网页元素。 相对于正则或其它方式匹配网页方式,phpQuery使用起来要方便的多。在使用phpQuery采集网页时,遇到一个问题:在处理大量网页之后,phpQuery占用的内存数量非常惊人(很快就超过了1G),
比如这段代码:
while (true) { phpQuery::newDocumentFile($htmlFile); // 处理网页元素... echo memory_get_usage() . "\n"; }
谨慎运行上面这段代码,它会很快用光你的内存。
经过查看phpQuery的源代码终于发现了问题所在,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"; }
内存占用稳定了。
ThinkPHP CURD方法之order方法详解
ThinkPHP CURD方法之where方法详解
CodeIgniter CLI模式简介
浅析ThinkPHP中execute和query方法的区别
Codeigniter上传图片出现“You did not select a file to upload”错误解决办法
Codeigniter出现错误提示Error with CACHE directory的解决方案
JS异常处理try..catch语句的作用和实例
smarty模板中使用get、post、request、cookies、session变量的方法
一个基于phpQuery的php通用采集类分享
php警告Creating default object from empty value 问题的解决方法
ThinkPHP使用UTFWry地址库进行IP定位实例
jQuery中的RadioButton,input,CheckBox取值赋值实现代码
PHP jQuery表单,带验证具体实现方法
php和jquery实现地图区域数据统计展示数据示例
使用phpQuery采集网页的方法
PHP反射类ReflectionClass和ReflectionObject的使用方法
php5.3 不支持 session_register() 此函数已启用的解决方法
session在php5.3中的变化 session_is_registered() is deprecated in
CodeIgniter使用phpcms模板引擎
CodeIgniter基本配置详细介绍
PHP set_error_handler()函数使用详解(示例)
PHP加密扩展库Mcrypt安装和实例
DOM XPATH获取img src值的query
php jq jquery getJSON跨域提交数据完整版
怎样使用php与jquery设置和读取cookies
mcrypt启用 加密以及解密过程详细解析
ueditor 1.2.6 使用方法说明
解决PHP mysql_query执行超时(Fatal error: Maximum execution time …)
jQuery+php实现ajax文件即时上传的详解