phpQuery占用内存过多的处理方法
发布:smiling 来源: PHP粉丝网 添加日期:2020-06-28 16:19:01 浏览: 评论:0
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";
- }
内存占用稳定了。
Tags: phpQuery占用内存
- 上一篇:php防止SQL注入详解及防范
- 下一篇:使用phpQuery采集网页的方法
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)