in reply to Re^3: Archive::Tar Memory deallocation problem
in thread Archive::Tar Memory deallocation problem

Can you please help me in understanding why the memory is hold by the perl code until it ends ? It keeps on increasing as it processes more and more tar files.Is there any way we can avoid it.
  • Comment on Re^4: Archive::Tar Memory deallocation problem

Replies are listed 'Best First'.
Re^5: Archive::Tar Memory deallocation problem
by mje (Curate) on Jan 28, 2009 at 14:30 UTC

    I tried this myself with Archive::Tar 1.44 on an ubuntu box and got out of memory almost straight away:

    use strict; use warnings; use Archive::Tar; use Devel::Leak; my $handle; my @results = qw ( u1.tar.gz u2.tar.gz u3.tar.gz u4.tar.gz u5.tar.gz u +6.tar.gz u7.tar.gz u8.tar.gz u9.tar.gz u10.tar.gz ); foreach my $tar_file ( @results ) { my $count = Devel::Leak::NoteSV($handle); print $count,"\n"; my $x = Archive::Tar->new or die "Failed to get tar object"; my $extracts = $x->read($tar_file); print "extracts $extracts\n"; $x->clear; undef $extracts; print Devel::Leak::CheckSV($handle), "\n"; }

    with 10 tar.gz files in the current directly all the same and of size 6.2Mb it fails with out of memory after only one:

    ~/tmp$ perl t.pl 28447 extracts 1 new 0x85fdce0 : new 0x85fdcec : loads and loads of these old (1): 0 old (1): 0 quite a lot of those 28647 28649 Out of memory!

    Tracking it through it failed in

    Archive::Tar::_read_tar(/usr/local/share/perl/5.8.8/Archive/Tar.pm:318 +): 318: my $offset = eval { tell $handle } || 'unknown'; DB<1> Out of memory!
      So does that imply it is a problem with Archive::Tar module?

        It looks possible but to be honest I'm not completely sure and I don't have the time to look into it more now.