在研究长期运行的perl程序是否存在内存泄漏时,我尝试使用Test::LeakTrace。
查看其报告的泄漏之一,我可以将泄漏的代码缩小到:
/$?/
正在运行:perl -MTest::LeakTrace::Script -e'/$?/'
打印:
从-e line 1泄露了SCALAR(0x10d3d48)。
为什么会这样,我需要担心吗?
更新:还尝试了Devel::LeakTrace::Fast,它没有抱怨相同的代码。
答案 0 :(得分:2)
假设你有泄漏。然后这个:
perl -e'/$?/ for 1..1E9'
应该让你的过程在内存中增长
ps -o rss,vsz <PID>
在我的情况下,它一直保持稳定。您应该检查它以进行设置。可能是您的模块检测到的泄漏是一些晚期破坏。你可以给模块作者写一个注释来帮助你找出它的输出,你可以帮助他们改进它......
BTW另一件确认“没有泄漏”的事情是
perl -MTest::LeakTrace::Script -e'/$?/ for 1..1000'
我没有看到多个泄露的标量,只有一个。