Linux::Info::NetStats - Collect linux net statistics.
use Linux::Info::NetStats; my $lxs = Linux::Info::NetStats->new; $lxs->init; sleep 1; my $stat = $lxs->get;
Or
my $lxs = Linux::Info::NetStats->new(initfile => $file); $lxs->init; my $stat = $lxs->get;
Linux::Info::NetStats gathers net statistics from the virtual /proc filesystem (procfs).
For more information read the documentation of the front-end module Linux::Info.
Generated by /proc/net/dev.
rxbyt - Number of bytes received per second. rxpcks - Number of packets received per second. rxerrs - Number of errors that happend while received packets per second. rxdrop - Number of packets that were dropped per second. rxfifo - Number of FIFO overruns that happend on received packets per second. rxframe - Number of carrier errors that happend on received packets per second. rxcompr - Number of compressed packets received per second. rxmulti - Number of multicast packets received per second. txbyt - Number of bytes transmitted per second. txpcks - Number of packets transmitted per second. txerrs - Number of errors that happend while transmitting packets per second. txdrop - Number of packets that were dropped per second. txfifo - Number of FIFO overruns that happend on transmitted packets per second. txcolls - Number of collisions that were detected per second. txcarr - Number of carrier errors that happend on transmitted packets per second. txcompr - Number of compressed packets transmitted per second. ttpcks - Number of total packets (received + transmitted) per second. ttbyt - Number of total bytes (received + transmitted) per second.
Call new() to create a new object.
new()
my $lxs = Linux::Info::NetStats->new;
Maybe you want to store/load the initial statistics to/from a file:
my $lxs = Linux::Info::NetStats->new(initfile => '/tmp/netstats.yml');
If you set initfile it's not necessary to call sleep before get().
initfile
get()
It's also possible to set the path to the proc filesystem.
Linux::Info::NetStats->new( files => { # This is the default path => '/proc', netdev => 'net/dev', } );
Call init() to initialize the statistics.
init()
$lxs->init;
Call get() to get the statistics. get() returns the statistics as a hash reference.
my $stat = $lxs->get;
The same as get_raw() but it's not necessary to call init() first.
Call get_raw() to get the raw data - no deltas.
get_raw()
Nothing.
proc(5)
Linux::Info
Alceu Rodrigues de Freitas Junior, <arfreitas@cpan.org>
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/>.
To install Linux::Info, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Linux::Info
CPAN shell
perl -MCPAN -e shell install Linux::Info
For more information on module installation, please visit the detailed CPAN module installation guide.