mirror of https://github.com/mikaku/Monitorix.git
Extended the features of a single-server in Multihost mode
Added the ability to show all graphs of a single server instead of showing only the System Load graph. #216
This commit is contained in:
parent
219eec240f
commit
a23d5337fe
2
Changes
2
Changes
|
@ -21,6 +21,8 @@
|
||||||
signal. This should also fix sporadic hangups in the HTTP and a truncation in
|
signal. This should also fix sporadic hangups in the HTTP and a truncation in
|
||||||
the rotated logfile.
|
the rotated logfile.
|
||||||
- Added in 'du.pm' the ability to count files in every directory defined. [#112]
|
- Added in 'du.pm' the ability to count files in every directory defined. [#112]
|
||||||
|
- Added the ability to show all graphs of a single server in Multihost mode,
|
||||||
|
instead of showing only the System Load graph. [#216]
|
||||||
- Fixed a bad memory scaling in *BSD systems.
|
- Fixed a bad memory scaling in *BSD systems.
|
||||||
- Fixed in 'process.pm' to fully honour the option 'netstats_in_bps'.
|
- Fixed in 'process.pm' to fully honour the option 'netstats_in_bps'.
|
||||||
- Fixed to force Monitorix to be started at the end of boot in systemd-based
|
- Fixed to force Monitorix to be started at the end of boot in systemd-based
|
||||||
|
|
155
monitorix.cgi
155
monitorix.cgi
|
@ -2,7 +2,7 @@
|
||||||
#
|
#
|
||||||
# Monitorix - A lightweight system monitoring tool.
|
# Monitorix - A lightweight system monitoring tool.
|
||||||
#
|
#
|
||||||
# Copyright (C) 2005-2017 by Jordi Sanfeliu <jordi@fibranet.cat>
|
# Copyright (C) 2005-2019 by Jordi Sanfeliu <jordi@fibranet.cat>
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or modify
|
# This program is free software; you can redistribute it and/or modify
|
||||||
# it under the terms of the GNU General Public License as published by
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
@ -139,31 +139,35 @@ sub multihost {
|
||||||
print "<br>\n";
|
print "<br>\n";
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
print " <table cellspacing='5' cellpadding='0' width='1' bgcolor='$colors->{graph_bg_color}' border='1'>\n";
|
if($cgi->{graph} eq "all") {
|
||||||
print " <tr>\n";
|
print " <iframe src='" . (split(',', $multihost->{remotehost_desc}->{$cgi->{val}}))[0] . (split(',', $multihost->{remotehost_desc}->{$cgi->{val}}))[2] . "/monitorix.cgi?mode=localhost&when=$cgi->{when}&graph=all&color=$cgi->{color}' height=100% width=100% frameborder=0 marginwidth=0 marginheight=0 scrolling=yes></iframe>\n";
|
||||||
print " <td bgcolor='$colors->{title_bg_color}'>\n";
|
} else {
|
||||||
print " <font face='Verdana, sans-serif' color='$colors->{fg_color}'>\n";
|
print " <table cellspacing='5' cellpadding='0' width='1' bgcolor='$colors->{graph_bg_color}' border='1'>\n";
|
||||||
print " <b> " . $host[$cgi->{val}] . "</b>\n";
|
print " <tr>\n";
|
||||||
print " </font>\n";
|
print " <td bgcolor='$colors->{title_bg_color}'>\n";
|
||||||
print " </td>\n";
|
print " <font face='Verdana, sans-serif' color='$colors->{fg_color}'>\n";
|
||||||
print " </tr>\n";
|
print " <b> " . $host[$cgi->{val}] . "</b>\n";
|
||||||
print " <tr>\n";
|
print " </font>\n";
|
||||||
print " <td bgcolor='$colors->{title_bg_color}' style='vertical-align: top; height: 10%; width: 10%;'>\n";
|
print " </td>\n";
|
||||||
print " <iframe src='" . (split(',', $multihost->{remotehost_desc}->{$cgi->{val}}))[0] . (split(',', $multihost->{remotehost_desc}->{$cgi->{val}}))[2] . "/monitorix.cgi?mode=localhost&when=$cgi->{when}&graph=$graph&color=$cgi->{color}&silent=imagetagbig' height=249 width=545 frameborder=0 marginwidth=0 marginheight=0 scrolling=no></iframe>\n";
|
print " </tr>\n";
|
||||||
print " </td>\n";
|
print " <tr>\n";
|
||||||
print " </tr>\n";
|
print " <td bgcolor='$colors->{title_bg_color}' style='vertical-align: top; height: 10%; width: 10%;'>\n";
|
||||||
print " <tr>\n";
|
print " <iframe src='" . (split(',', $multihost->{remotehost_desc}->{$cgi->{val}}))[0] . (split(',', $multihost->{remotehost_desc}->{$cgi->{val}}))[2] . "/monitorix.cgi?mode=localhost&when=$cgi->{when}&graph=$graph&color=$cgi->{color}&silent=imagetagbig' height=249 width=545 frameborder=0 marginwidth=0 marginheight=0 scrolling=no></iframe>\n";
|
||||||
if(lc($multihost->{footer_url}) eq "y") {
|
print " </td>\n";
|
||||||
print " <td bgcolor='$colors->{title_bg_color}'>\n";
|
print " </tr>\n";
|
||||||
print " <font face='Verdana, sans-serif' color='$colors->{title_fg_color}'>\n";
|
print " <tr>\n";
|
||||||
print " <font size='-1'>\n";
|
if(lc($multihost->{footer_url}) eq "y") {
|
||||||
print " <b> <a href='" . $foot_url[$cgi->{val}] . "' style='color: " . $colors->{title_fg_color} . ";'>$foot_url[$cgi->{val}]</a></b>\n";
|
print " <td bgcolor='$colors->{title_bg_color}'>\n";
|
||||||
print " </font></font>\n";
|
print " <font face='Verdana, sans-serif' color='$colors->{title_fg_color}'>\n";
|
||||||
print " </td>\n";
|
print " <font size='-1'>\n";
|
||||||
|
print " <b> <a href='" . $foot_url[$cgi->{val}] . "' style='color: " . $colors->{title_fg_color} . ";'>$foot_url[$cgi->{val}]</a></b>\n";
|
||||||
|
print " </font></font>\n";
|
||||||
|
print " </td>\n";
|
||||||
|
}
|
||||||
|
print " </tr>\n";
|
||||||
|
print " </table>\n";
|
||||||
|
print " <br>\n";
|
||||||
}
|
}
|
||||||
print " </tr>\n";
|
|
||||||
print " </table>\n";
|
|
||||||
print " <br>\n";
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -412,6 +416,7 @@ if($RRDs::VERSION > 1.2) {
|
||||||
if(!$silent) {
|
if(!$silent) {
|
||||||
my $title;
|
my $title;
|
||||||
my $str;
|
my $str;
|
||||||
|
my @output;
|
||||||
|
|
||||||
my $piwik_code = "";
|
my $piwik_code = "";
|
||||||
my ($piwik_url, $piwik_sid, $piwik_img);
|
my ($piwik_url, $piwik_sid, $piwik_img);
|
||||||
|
@ -456,65 +461,73 @@ EOF
|
||||||
print(" <body bgcolor='" . $colors{bg_color} . "' vlink='#888888' link='#888888'>\n");
|
print(" <body bgcolor='" . $colors{bg_color} . "' vlink='#888888' link='#888888'>\n");
|
||||||
print(" $piwik_code\n");
|
print(" $piwik_code\n");
|
||||||
print(" <center>\n");
|
print(" <center>\n");
|
||||||
print(" <table cellspacing='5' cellpadding='0' bgcolor='" . $colors{graph_bg_color} . "' border='1'>\n");
|
push(@output, " <table cellspacing='5' cellpadding='0' bgcolor='" . $colors{graph_bg_color} . "' border='1'>\n");
|
||||||
print(" <tr>\n");
|
push(@output, " <tr>\n");
|
||||||
|
|
||||||
if(lc($config{enable_back_button} || "") eq "y") {
|
if(lc($config{enable_back_button} || "") eq "y") {
|
||||||
print(" <span style='color:#888888;position:fixed;left:1em;font-size:32px;letter-spacing:-1px;'><a href='javascript:history.back()' style='text-decoration:none;'>◀</a>\n");
|
push(@output, " <span style='color:#888888;position:fixed;left:1em;font-size:32px;letter-spacing:-1px;'><a href='javascript:history.back()' style='text-decoration:none;'>◀</a>\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if(($val ne "all" || $val ne "group") && $mode ne "multihost") {
|
if(($val ne "all" || $val ne "group") && $mode ne "multihost") {
|
||||||
print(" <td bgcolor='" . $colors{title_bg_color} . "'>\n");
|
push(@output, " <td bgcolor='" . $colors{title_bg_color} . "'>\n");
|
||||||
print(" <font face='Verdana, sans-serif' color='" . $colors{title_fg_color} . "'>\n");
|
push(@output, " <font face='Verdana, sans-serif' color='" . $colors{title_fg_color} . "'>\n");
|
||||||
print(" <font size='5'><b> Host: </b></font>\n");
|
push(@output, " <font size='5'><b> Host: </b></font>\n");
|
||||||
print(" </font>\n");
|
push(@output, " </font>\n");
|
||||||
print(" </td>\n");
|
push(@output, " </td>\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if($val =~ m/group(\d+)/) {
|
if($val =~ m/group(\d+)/) {
|
||||||
my $gnum = $1;
|
my $gnum = $1;
|
||||||
my $gname = (split(',', $config{multihost}->{remotegroup_list}))[$gnum];
|
my $gname = (split(',', $config{multihost}->{remotegroup_list}))[$gnum];
|
||||||
$gname = trim($gname);
|
$gname = trim($gname);
|
||||||
print(" <td bgcolor='" . $colors{title_bg_color} . "'>\n");
|
push(@output, " <td bgcolor='" . $colors{title_bg_color} . "'>\n");
|
||||||
print(" <font face='Verdana, sans-serif' color='" . $colors{title_fg_color} . "'>\n");
|
push(@output, " <font face='Verdana, sans-serif' color='" . $colors{title_fg_color} . "'>\n");
|
||||||
print(" <font size='5'><b> $gname </b></font>\n");
|
push(@output, " <font size='5'><b> $gname </b></font>\n");
|
||||||
print(" </font>\n");
|
push(@output, " </font>\n");
|
||||||
print(" </td>\n");
|
push(@output, " </td>\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
print(" <td bgcolor='" . $colors{bg_color} . "'>\n");
|
push(@output, " <td bgcolor='" . $colors{bg_color} . "'>\n");
|
||||||
print(" <font face='Verdana, sans-serif' color='" . $colors{fg_color} . "'>\n");
|
push(@output, " <font face='Verdana, sans-serif' color='" . $colors{fg_color} . "'>\n");
|
||||||
if($mode eq "localhost" || $mode eq "traffacct") {
|
if($mode eq "localhost" || $mode eq "traffacct") {
|
||||||
$title = $config{hostname};
|
$title = $config{hostname};
|
||||||
} elsif($mode eq "multihost") {
|
} elsif($mode eq "multihost") {
|
||||||
$graph = $graph eq "all" ? "_system1" : $graph;
|
# $graph = $graph eq "all" ? "_system1" : $graph;
|
||||||
my ($g1, $g2) = ($graph =~ /(_\D+).*?(\d)$/);
|
if($graph ne "all") {
|
||||||
if($g1 eq "_port") {
|
my ($g1, $g2) = ($graph =~ /(_\D+).*?(\d)$/);
|
||||||
$title = $config{graphs}->{$g1};
|
if($g1 eq "_port") {
|
||||||
$g2 = trim((split(',', $config{port}->{list}))[$g2]);
|
$title = $config{graphs}->{$g1};
|
||||||
$title .= " " . $g2;
|
$g2 = trim((split(',', $config{port}->{list}))[$g2]);
|
||||||
$g2 = (split(',', $config{port}->{desc}->{$g2}))[0];
|
$title .= " " . $g2;
|
||||||
$title .= " (" . trim($g2) . ")";
|
$g2 = (split(',', $config{port}->{desc}->{$g2}))[0];
|
||||||
|
$title .= " (" . trim($g2) . ")";
|
||||||
|
} else {
|
||||||
|
$g2 = "" if $g1 eq "_proc"; # '_procn' must be converted to '_proc'
|
||||||
|
$title = $config{graphs}->{$g1 . $g2};
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
$g2 = "" if $g1 eq "_proc"; # '_procn' must be converted to '_proc'
|
$title = $graph eq "all" ? $config{graphs}->{_system1} : $graph;
|
||||||
$title = $config{graphs}->{$g1 . $g2};
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$title =~ s/ / /g;
|
$title =~ s/ / /g;
|
||||||
my $twhen = $tf{nwhen} > 1 ? "$tf{nwhen} $tf{twhen}" : $tf{twhen};
|
my $twhen = $tf{nwhen} > 1 ? "$tf{nwhen} $tf{twhen}" : $tf{twhen};
|
||||||
$twhen .= "s" if $tf{nwhen} > 1;
|
$twhen .= "s" if $tf{nwhen} > 1;
|
||||||
print(" <font size='5'><b> $title </b></font>\n");
|
|
||||||
print(" </font>\n");
|
if($mode ne "multihost" || $graph ne "all" || $val eq "all") {
|
||||||
print(" </td>\n");
|
print @output;
|
||||||
print(" <td bgcolor='" . $colors{title_bg_color} . "'>\n");
|
print(" <font size='5'><b> $title </b></font>\n");
|
||||||
print(" <font face='Verdana, sans-serif' color='" . $colors{title_fg_color} . "'>\n");
|
|
||||||
print(" <font size='5'><b> last $twhen </b></font>\n");
|
|
||||||
print(" </font>\n");
|
print(" </font>\n");
|
||||||
print(" </td>\n");
|
print(" </td>\n");
|
||||||
print(" </tr>\n");
|
print(" <td bgcolor='" . $colors{title_bg_color} . "'>\n");
|
||||||
print(" </table>\n");
|
print(" <font face='Verdana, sans-serif' color='" . $colors{title_fg_color} . "'>\n");
|
||||||
print(" <font face='Verdana, sans-serif' color='" . $colors{fg_color} . "'>\n");
|
print(" <font size='5'><b> last $twhen </b></font>\n");
|
||||||
print encode('utf-8', " <h4><font color='#888888'>" . strftime("%a %b %e %H:%M:%S %Z %Y", localtime) . "</font></h4>\n");
|
print(" </font>\n");
|
||||||
|
print(" </td>\n");
|
||||||
|
print(" </tr>\n");
|
||||||
|
print(" </table>\n");
|
||||||
|
print(" <font face='Verdana, sans-serif' color='" . $colors{fg_color} . "'>\n");
|
||||||
|
print encode('utf-8', " <h4><font color='#888888'>" . strftime("%a %b %e %H:%M:%S %Z %Y", localtime) . "</font></h4>\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -623,16 +636,18 @@ if($mode eq "localhost") {
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!$silent) {
|
if(!$silent) {
|
||||||
print("\n");
|
if($mode ne "multihost" || $graph ne "all" || $val eq "all") {
|
||||||
print(" </font>\n");
|
print("\n");
|
||||||
print(" </center>\n");
|
print(" </font>\n");
|
||||||
print("<!-- footer begins -->\n");
|
print(" </center>\n");
|
||||||
print(" <p>\n");
|
print("<!-- footer begins -->\n");
|
||||||
print(" <a href='http://www.monitorix.org'><img src='" . $config{url} . "/" . $config{logo_bottom} . "' border='0'></a>\n");
|
print(" <p>\n");
|
||||||
print(" <br>\n");
|
print(" <a href='http://www.monitorix.org'><img src='" . $config{url} . "/" . $config{logo_bottom} . "' border='0'></a>\n");
|
||||||
print(" <font face='Verdana, sans-serif' color='" . $colors{fg_color} . "' size='-2'>\n");
|
print(" <br>\n");
|
||||||
print("Copyright © 2005-2017 Jordi Sanfeliu\n");
|
print(" <font face='Verdana, sans-serif' color='" . $colors{fg_color} . "' size='-2'>\n");
|
||||||
print(" </font>\n");
|
print("Copyright © 2005-2017 Jordi Sanfeliu\n");
|
||||||
|
print(" </font>\n");
|
||||||
|
}
|
||||||
print(" </body>\n");
|
print(" </body>\n");
|
||||||
print("</html>\n");
|
print("</html>\n");
|
||||||
print("<!-- footer ends -->\n");
|
print("<!-- footer ends -->\n");
|
||||||
|
|
Loading…
Reference in New Issue