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:
Jordi Sanfeliu 2019-01-02 09:56:36 +01:00
parent 219eec240f
commit a23d5337fe
2 changed files with 87 additions and 70 deletions

View File

@ -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

View File

@ -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>&nbsp;&nbsp;" . $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>&nbsp;&nbsp;" . $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>&nbsp;&nbsp;<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>&nbsp;&nbsp;<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;'>&#9664;</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;'>&#9664;</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>&nbsp;&nbsp;Host:&nbsp;</b></font>\n"); push(@output, " <font size='5'><b>&nbsp;&nbsp;Host:&nbsp;</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>&nbsp;&nbsp;$gname&nbsp;</b></font>\n"); push(@output, " <font size='5'><b>&nbsp;&nbsp;$gname&nbsp;</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/ /&nbsp;/g; $title =~ s/ /&nbsp;/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>&nbsp;&nbsp;$title&nbsp;&nbsp;</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>&nbsp;&nbsp;$title&nbsp;&nbsp;</b></font>\n");
print(" <font face='Verdana, sans-serif' color='" . $colors{title_fg_color} . "'>\n");
print(" <font size='5'><b>&nbsp;&nbsp;last&nbsp;$twhen&nbsp;&nbsp;</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>&nbsp;&nbsp;last&nbsp;$twhen&nbsp;&nbsp;</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 &copy; 2005-2017 Jordi Sanfeliu\n"); print(" <font face='Verdana, sans-serif' color='" . $colors{fg_color} . "' size='-2'>\n");
print(" </font>\n"); print("Copyright &copy; 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");