2

我想我在通过 HTTPS 连接时发现了 LWP 的内存泄漏。使用以下脚本,内存使用量不断增加:

use LWP::UserAgent;

$ua = LWP::UserAgent->new();
$request = HTTP::Request->new(GET=>'https://www.google.com/');
while (1) {
  $response = $ua->request($request);
  sleep(1);
}

这个其他脚本没有问题:

use LWP::UserAgent;

$ua = LWP::UserAgent->new();
$request = HTTP::Request->new(GET=>'http://www.google.com/'); # https => http
while (1) {
  $response = $ua->request($request);
  sleep(1);
}

Perl 5.12.3 / LWP 5.837 / Crypt::SSLeay 0.58 / Mac OS X 10.7.4

有谁知道解决这个问题的方法?


更新

Perl 5.12.4 / LWP 6.05 / Crypt::SSLeay 0.64 / Mac OS X 10.8.4

通过 HTTPS 连接时仍然存在内存泄漏。要试用它,请在终端上运行示例脚本,然后使用活动监视器查看内存增长和增长。


更新

经过一些测试,我发现,随着我的库最近升级,仍然存在内存泄漏,但只有当您通过 HTTPS 调用某些地址时才会发生这种情况。在上面的示例中,我调用了https://www.google.com,它恰好是这些地址之一。例如,这段代码没有给我任何内存泄漏:

use LWP::UserAgent;

$ua = LWP::UserAgent->new();
$request = HTTP::Request->new(GET=>'https://twitter.com/'); # www.google.com => twitter.com
while (1) {
  $response = $ua->request($request);
  sleep(1);
}


更新

我报告了这个错误,其他一些人也证实了我的发现: https ://rt.cpan.org/Ticket/Display.html?id=88287

4

2 回答 2

1

至少对我来说,您可以通过禁用验证主机名来解决此问题:

my $ua = LWP::UserAgent->new(ssl_opts => { verify_hostname => 0 });

显然,如果安全性对您的应用程序很重要,则不建议这样做!

于 2014-07-13T19:23:23.467 回答
1

在 Linux 上,使用 perl 5.10、Crypt 0.58、Lwp 6.02,内存使用量是恒定的。尝试将您的 perl 模块升级到最新的。

如果问题仍然存在,请为此问题创建 RT 票证,此模块的维护者将修复泄漏。

问候,

于 2012-10-02T07:34:52.413 回答