小编Sha*_*ike的帖子

PHP XML 内存泄漏?

我们在定期运行的脚本之一中出现了严重的内存泄漏,该脚本迅速清除了服务器上的可用内存。尽管进行了数小时的研究和实验,但我什至无法对它产生影响。

这是代码:

    echo '1:'.memory_get_usage()."\n";
ini_set('memory_limit', '1G');
    echo '2:'.memory_get_usage()."\n";

$oXML = new DOMDocument();
    echo '3:'.memory_get_usage()."\n";
$oXML->load('feed.xml'); # 556 MB file
    echo '4:'.memory_get_usage()."\n";

$xpath = new DOMXPath($oXML);
    echo '5:'.memory_get_usage()."\n";
$oNodes = $xpath->query('//feed/item'); # 270,401 items
    echo '6:'.memory_get_usage()."\n";

unset($xpath);
    echo '7:'.memory_get_usage()."\n";
unset($oNodes);
    echo '8:'.memory_get_usage()."\n";
unset($oXML);
    echo '9:'.memory_get_usage()."\n";
Run Code Online (Sandbox Code Playgroud)

这是输出:

1:679016
2:679320
3:680128
4:680568
5:681304
6:150852408
7:150851840
8:34169968
9:34169448
Run Code Online (Sandbox Code Playgroud)

如您所见,当我们使用 xpath 将节点加载到对象中时,内存使用量从 681,304 跃升至 150,852,408。我对此并不十分担心。

我的问题是,即使在销毁 $oNodes 对象之后,我们仍然停留在 34,169,968 的内存使用量上。

真正的问题是 PHP 显示的内存使用量只是脚本消耗的总内存的一小部分。free -m直接从服务器上的命令行使用,我们从使用的 3,295 MB 内存增加到 5,226 MB ——并且永远不会减少 …

php memory xpath dom memory-leaks

5
推荐指数
1
解决办法
1208
查看次数

标签 统计

dom ×1

memory ×1

memory-leaks ×1

php ×1

xpath ×1