mirror of
https://github.com/munin-monitoring/contrib.git
synced 2018-11-08 00:59:34 +01:00
Update rtom_allsessions_mem
Add ip / port function
This commit is contained in:
parent
f519cf3ad4
commit
80dcbf7231
@ -24,16 +24,23 @@
|
||||
#
|
||||
# src "socket" when using scgi_socket, or anything else when using scgi_port
|
||||
# socket rTorrent's rpc socket (scgi_local) - using scgi_local - needed, when "src" is set to "socket"
|
||||
# ip rTorrent's ip address - using scgi_port - needed, when "src" is NOT set to "socket"
|
||||
# port rTorrent's scgi port (scgi_port) - using scgi_port - needed, when "src" is NOT set to "socket"
|
||||
# category Change graph category
|
||||
#
|
||||
# Configuration example
|
||||
#
|
||||
# [rtom_all]
|
||||
# [rtom_allsessions_*]
|
||||
# user username
|
||||
# env.src socket
|
||||
# env.socket /home/user/torrent/.socket/rpc.socket,/home/user/torrent/.socket/rpc.socket
|
||||
# env.category Category
|
||||
#
|
||||
# [rtom_allsessions_*]
|
||||
# user username
|
||||
# env.port 5000,5001,5002,5003
|
||||
# env.category Category
|
||||
#
|
||||
#%# family=auto
|
||||
|
||||
|
||||
@ -55,33 +62,48 @@ if ( $ARGV[0] and $ARGV[0] eq "config" ) {
|
||||
}
|
||||
|
||||
use IO::Socket;
|
||||
my @sockets = split /,/, $ENV{"socket"} || "";
|
||||
my $mem = 0;
|
||||
my $src = $ENV{"src"} || "";
|
||||
my @sockets = split /,/, $ENV{"socket"} || "";
|
||||
my $ip = $ENV{"ip"} || "127.0.0.1";
|
||||
my @ports = split /,/, $ENV{"port"} || "";
|
||||
|
||||
my $mem = 0;
|
||||
my $pattern = qr/<value><(int|i4|i8|ex\.i8)>(\d+)<\/(int|i4|i8|ex\.i8)><\/value>/;
|
||||
my $line = "<?xml version=\"1.0\" encoding=\"utf-8\"?><methodCall><methodName>get_memory_usage</methodName></methodCall>";
|
||||
my $llen = length $line;
|
||||
my $header = "CONTENT_LENGTH\000${llen}\000SCGI\001\000";
|
||||
my $hlen = length $header;
|
||||
$line = "${hlen}:${header},${line}";
|
||||
|
||||
for $socket (@sockets)
|
||||
{
|
||||
if ( ( defined $src ) && ( $src eq "socket" ) ) {
|
||||
if ( ( defined $src ) && ( $src eq "socket" ) ) {
|
||||
for $socket (@sockets)
|
||||
{
|
||||
socket( SOCK, PF_UNIX, SOCK_STREAM, 0 ) or die;
|
||||
connect( SOCK, sockaddr_un( $socket ) ) or die $!;
|
||||
}
|
||||
|
||||
print SOCK $line;
|
||||
flush SOCK;
|
||||
|
||||
while ( $line = <SOCK> ) {
|
||||
if ( $line =~ /$pattern/ ) {
|
||||
$mem = $mem + $2;
|
||||
my $line = "${hlen}:${header},${line}";
|
||||
print SOCK $line;
|
||||
flush SOCK;
|
||||
while ( $line = <SOCK> ) {
|
||||
if ( $line =~ /$pattern/ ) {
|
||||
$mem = $mem + $2;
|
||||
}
|
||||
}
|
||||
close (SOCK);
|
||||
}
|
||||
} else {
|
||||
for $port (@ports)
|
||||
{
|
||||
socket( SOCK, PF_INET, SOCK_STREAM, getprotobyname( "tcp" ) );
|
||||
connect( SOCK, sockaddr_in( $port, inet_aton( $ip ) ) );
|
||||
my $line = "${hlen}:${header},${line}";
|
||||
print SOCK $line;
|
||||
flush SOCK;
|
||||
while ( $line = <SOCK> ) {
|
||||
if ( $line =~ /$pattern/ ) {
|
||||
$mem = $mem + $2;
|
||||
}
|
||||
}
|
||||
close (SOCK);
|
||||
}
|
||||
close (SOCK);
|
||||
}
|
||||
|
||||
print "mem.value ${mem}\n";
|
||||
|
Loading…
Reference in New Issue
Block a user