mirror of https://github.com/mikaku/Monitorix.git
introduced the option 'enable_parallelizing' in order to speed up the graph generation in multi-core systems
This commit is contained in:
parent
7d82b39456
commit
5828a81086
2
Changes
2
Changes
|
@ -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]
|
||||||
|
|
|
@ -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> $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> $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($@) {
|
||||||
|
|
|
@ -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/
|
||||||
|
|
Loading…
Reference in New Issue