introduced the option 'enable_parallelizing' in order to speed up the graph generation in multi-core systems

This commit is contained in:
Jordi Sanfeliu 2017-07-19 16:26:10 +02:00
parent 7d82b39456
commit 5828a81086
3 changed files with 59 additions and 13 deletions

View File

@ -13,6 +13,8 @@
in bytes, so the y-axis will scale accordingly. in bytes, so the y-axis will scale accordingly.
- Changed to be more thickness the lines of Greylisting graph in 'mail.pm'. - Changed to be more thickness the lines of Greylisting graph in 'mail.pm'.
- Changed the colors of the main graph in 'ftp.pm'. - Changed the colors of the main graph in 'ftp.pm'.
- Introduced the option 'enable_parallelizing' in order to speed up the graph
generation in multi-core systems.
- Added a new option in 'port.rrd' to enable/disable background red color for - Added a new option in 'port.rrd' to enable/disable background red color for
each port monitored. [#182] each port monitored. [#182]
- Added to be able to change the real names in the Voltage graph. [#183] - Added to be able to change the real names in the Voltage graph. [#183]

View File

@ -169,21 +169,27 @@ sub multihost {
sub graph_header { sub graph_header {
my ($title, $colspan) = @_; my ($title, $colspan) = @_;
print("\n"); my @output;
print("<!-- graph table begins -->\n");
print(" <table cellspacing='5' cellpadding='0' width='1' bgcolor='$colors{graph_bg_color}' border='1'>\n"); push(@output, "\n");
print(" <tr>\n"); push(@output, "<!-- graph table begins -->\n");
print(" <td bgcolor='$colors{title_bg_color}' colspan='$colspan'>\n"); push(@output, " <table cellspacing='5' cellpadding='0' width='1' bgcolor='$colors{graph_bg_color}' border='1'>\n");
print(" <font face='Verdana, sans-serif' color='$colors{title_fg_color}'>\n"); push(@output, " <tr>\n");
print(" <b>&nbsp;&nbsp;$title</b>\n"); push(@output, " <td bgcolor='$colors{title_bg_color}' colspan='$colspan'>\n");
print(" </font>\n"); push(@output, " <font face='Verdana, sans-serif' color='$colors{title_fg_color}'>\n");
print(" </td>\n"); push(@output, " <b>&nbsp;&nbsp;$title</b>\n");
print(" </tr>\n"); push(@output, " </font>\n");
push(@output, " </td>\n");
push(@output, " </tr>\n");
return @output;
} }
sub graph_footer { sub graph_footer {
print(" </table>\n"); my @output;
print("<!-- graph table ends -->\n");
push(@output, " </table>\n");
push(@output, "<!-- graph table ends -->\n");
return @output;
} }
@ -506,6 +512,9 @@ $cgi{val} = $val;
$cgi{silent} = $silent; $cgi{silent} = $silent;
if($mode eq "localhost") { if($mode eq "localhost") {
my $children = 0;
my %outputs; # a hash of arrays
foreach (split(',', $config{graph_name})) { foreach (split(',', $config{graph_name})) {
my $gn = trim($_); my $gn = trim($_);
my $g = ""; my $g = "";
@ -524,12 +533,46 @@ if($mode eq "localhost") {
if($graph eq "all" || $gn eq $g) { if($graph eq "all" || $gn eq $g) {
no strict "refs"; no strict "refs";
&$cgi($gn, \%config, \%cgi);
if(lc($config{enable_parallelizing} || "") eq "y") {
pipe(CHILD_RDR, PARENT_WTR);
PARENT_WTR->autoflush(1);
$children++;
if(!fork()) { # child
my @output;
close(CHILD_RDR);
@output = &$cgi($gn, \%config, \%cgi);
print(PARENT_WTR @output);
close(PARENT_WTR);
exit(0);
} else { # parent
my @output;
close(PARENT_WTR);
@output = <CHILD_RDR>;
$outputs{$gn} = \@output;
close(CHILD_RDR);
}
} else {
my @output = &$cgi($gn, \%config, \%cgi);
print @output;
}
} }
} }
} }
if(lc($config{enable_parallelizing} || "") eq "y") {
while($children--) {
waitpid(-1, 0); # wait for all children
}
foreach (split(',', $config{graph_name})) {
my $gn = trim($_);
print @{$outputs{$gn}} if $outputs{$gn};
}
}
} elsif($mode eq "multihost") { } elsif($mode eq "multihost") {
multihost(\%config, \%colors, \%cgi); multihost(\%config, \%colors, \%cgi);
} elsif($mode eq "traffacct") { } elsif($mode eq "traffacct") {
eval "use $mode qw(traffacct_cgi)"; eval "use $mode qw(traffacct_cgi)";
if($@) { if($@) {

View File

@ -17,6 +17,7 @@ global_zoom = 1
max_historic_years = 1 max_historic_years = 1
accept_selfsigned_certs = y accept_selfsigned_certs = y
image_format = PNG image_format = PNG
enable_parallelizing = y
include_dir = /etc/monitorix/conf.d include_dir = /etc/monitorix/conf.d
base_dir = /var/lib/monitorix/www/ base_dir = /var/lib/monitorix/www/