zentara has asked for the wisdom of the Perl Monks concerning the following question:

I was playing around with top to monitor a program for memory size, and noticed that the output of top (for size) dosn't match the output of Proc::ProcessTable. Anyone know the explanation? Run the 2 sample scripts on the same process.
#!/usr/bin/perl use warnings; use strict; use IPC::Open3; use Tk; my $pid = shift; my $pid1 = open3(0, \*READ,0,"top -d 1 -b -p $pid "); waitpid($pid1, 1); my $sizeold = 0; my $mw = new MainWindow; $mw->overrideredirect(1); my $t = $mw->Text(-width=>25, -height=>1, -bg=>'black',-fg=>'yellow')- +>pack; my $id = Tk::After->new($mw,50,'repeat',\&refresh); MainLoop; sub refresh{ my @words = split(/\s+/,<READ>); $words[0] ||= 0; if($words[0] =~ /$pid/){ $t->delete('1.0','end'); $t->insert('end',"PID: $pid -> $words[4]"); if($words[4] != $sizeold){print chr(07)} $sizeold = $words[4]; } }
###########################################################

#!/usr/bin/perl use warnings; use strict; use Tk; use Proc::ProcessTable; #Dosn't give same size as top ? my $sizeold = 0; my $pid = shift; my $t = new Proc::ProcessTable; my $p; foreach my $p1 (@{$t->table}){ if($p1->pid =~ /$pid/){ $p = $p1 } } my $mw = new MainWindow; $mw->overrideredirect(1); my $text = $mw->Text(-width=>25, -height=>1, -bg=>'black',-fg=>'yellow +')->pack; my $id = Tk::After->new($mw,50,'repeat',\&refresh); MainLoop; sub refresh{ $text->delete('1.0','end'); my $insert= 'PID: '.$p->pid.' -> '.$p->size; $text->insert('end',$insert); if($p->size != $sizeold){print chr(07)} $sizeold = $p->size; # print $p->pid," ",$p->cmndline," ",$p->size,"\n"; }

I'm not really a human, but I play one on earth. flash japh

Replies are listed 'Best First'.
Re: top size output not matching Proc::ProcessTable
by liz (Monsignor) on Mar 14, 2004 at 22:48 UTC
    FWIW, I've used the following approach for Benchmark::Thread::Size:
    my $wpi; BEGIN { if ($^O =~ m#MSWin#) { require Win32::Process::Info; $wpi = Win32::Process::Info->new; } } # code my $size; if ($wpi) { $size = ($wpi->GetProcInfo( $pid ))[0]->{'WorkingSetSize'}/1024; } else { open( my $ps,"ps -o rss= -p $pid |" ) or die "Could not ps -o rss= -p $pid: $!\n"; while (<$ps>) { $size = $1 if m#(\d+)#; } }
    which seems to be a good platform-independent solution.

    Liz

Re: top size output not matching Proc::ProcessTable
by tachyon (Chancellor) on Mar 14, 2004 at 23:07 UTC

    top is/was somewhat broken with respect to accurately counting memory used by threads It is/was a known issue.

    cheers

    tachyon

Re: top size output not matching Proc::ProcessTable
by zentara (Cardinal) on Mar 15, 2004 at 16:04 UTC
    Thanks for the tips. I see now that that the (output for size from Proc::ProcessTable) equals (the size output from ps)*(1.024)

    I should have guessed that. :-)


    I'm not really a human, but I play one on earth. flash japh