NAME
Linux::Info::ProcStats - Collect linux process statistics.
SYNOPSIS
use Linux::Info::ProcStats;
my $lxs = Linux::Info::ProcStats->new;
$lxs->init;
sleep 1;
my $stat = $lxs->get;
Or
my $lxs = Linux::Info::ProcStats->new(initfile => $file);
$lxs->init;
my $stat = $lxs->get;
DESCRIPTION
Linux::Info::ProcStats gathers process statistics from the virtual /proc filesystem (procfs).
For more information read the documentation of the front-end module Linux::Info.
IMPORTANT
I renamed key procs_blocked
to blocked
!
LOAD AVERAGE STATISTICS
Generated by /proc/stat and /proc/loadavg.
new - Number of new processes that were produced per second.
runqueue - The number of currently executing kernel scheduling entities (processes, threads).
count - The number of kernel scheduling entities that currently exist on the system (processes, threads).
blocked - Number of processes blocked waiting for I/O to complete (Linux 2.5.45 onwards).
running - Number of processes in runnable state (Linux 2.5.45 onwards).
METHODS
new()
Call new()
to create a new object.
my $lxs = Linux::Info::ProcStats->new;
Maybe you want to store/load the initial statistics to/from a file:
my $lxs = Linux::Info::ProcStats->new(initfile => '/tmp/procstats.yml');
If you set initfile
it's not necessary to call sleep before get()
.
It's also possible to set the path to the proc filesystem.
Linux::Info::ProcStats->new(
files => {
# This is the default
path => '/proc',
loadavg => 'loadavg',
stat => 'stat',
}
);
init()
Call init()
to initialize the statistics.
$lxs->init;
get()
Call get()
to get the statistics. get()
returns the statistics as a hash reference.
my $stat = $lxs->get;
raw()
Get raw values.
EXPORTS
Nothing.
SEE ALSO
proc(5)
AUTHOR
Alceu Rodrigues de Freitas Junior, <arfreitas@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2015 of Alceu Rodrigues de Freitas Junior, <arfreitas@cpan.org>
This file is part of Linux Info project.
Linux Info is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
Linux Info is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with Linux Info. If not, see <http://www.gnu.org/licenses/>.