mirror of https://github.com/mikaku/Monitorix.git
1687 lines
63 KiB
Perl
1687 lines
63 KiB
Perl
#
|
|
# Monitorix - A lightweight system monitoring tool.
|
|
#
|
|
# Copyright (C) 2005-2022 by Jordi Sanfeliu <jordi@fibranet.cat>
|
|
#
|
|
# 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
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along
|
|
# with this program; if not, write to the Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
#
|
|
|
|
package pagespeed;
|
|
|
|
use strict;
|
|
use warnings;
|
|
use Monitorix;
|
|
use RRDs;
|
|
use LWP::UserAgent;
|
|
use XML::Simple;
|
|
use Exporter 'import';
|
|
our @EXPORT = qw(pagespeed_init pagespeed_update pagespeed_cgi);
|
|
|
|
sub pagespeed_init {
|
|
my $myself = (caller(0))[3];
|
|
my ($package, $config, $debug) = @_;
|
|
my $rrd = $config->{base_lib} . $package . ".rrd";
|
|
my $pagespeed = $config->{pagespeed};
|
|
|
|
my $info;
|
|
my @ds;
|
|
my @rra;
|
|
my @tmp;
|
|
my $n;
|
|
|
|
my @average;
|
|
my @min;
|
|
my @max;
|
|
my @last;
|
|
|
|
if(-e $rrd) {
|
|
$info = RRDs::info($rrd);
|
|
for my $key (keys %$info) {
|
|
if(index($key, 'ds[') == 0) {
|
|
if(index($key, '.type') != -1) {
|
|
push(@ds, substr($key, 3, index($key, ']') - 3));
|
|
}
|
|
}
|
|
if(index($key, 'rra[') == 0) {
|
|
if(index($key, '.rows') != -1) {
|
|
push(@rra, substr($key, 4, index($key, ']') - 4));
|
|
}
|
|
}
|
|
}
|
|
if(scalar(@ds) / 59 != scalar(my @bl = split(',', $pagespeed->{list}))) {
|
|
logger("$myself: Detected size mismatch between 'list' (" . scalar(my @bl = split(',', $pagespeed->{list})) . ") and $rrd (" . scalar(@ds) / 59 . "). Resizing it accordingly. All historical data will be lost. Backup file created.");
|
|
rename($rrd, "$rrd.bak");
|
|
}
|
|
if(scalar(@rra) < 12 + (4 * $config->{max_historic_years})) {
|
|
logger("$myself: Detected size mismatch between 'max_historic_years' (" . $config->{max_historic_years} . ") and $rrd (" . ((scalar(@rra) -12) / 4) . "). Resizing it accordingly. All historical data will be lost. Backup file created.");
|
|
rename($rrd, "$rrd.bak");
|
|
}
|
|
}
|
|
|
|
if(!(-e $rrd)) {
|
|
logger("Creating '$rrd' file.");
|
|
for($n = 1; $n <= $config->{max_historic_years}; $n++) {
|
|
push(@average, "RRA:AVERAGE:0.5:1440:" . (365 * $n));
|
|
push(@min, "RRA:MIN:0.5:1440:" . (365 * $n));
|
|
push(@max, "RRA:MAX:0.5:1440:" . (365 * $n));
|
|
push(@last, "RRA:LAST:0.5:1440:" . (365 * $n));
|
|
}
|
|
for($n = 0; $n < scalar(my @bl = split(',', $pagespeed->{list})); $n++) {
|
|
push(@tmp, "DS:pagespeed" . $n . "_catim:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_cahit:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_camis:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_cabhit:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_cabmis:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_cafal:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_caexp:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_cains:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_cadel:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_caext:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_notca:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_fihit:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_fiins:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_fimis:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_lrhit:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_lrins:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_lrmis:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_mcahit:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_mcains:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_mcamis:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_mcbhit:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_mcbins:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_mcbmis:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_pcbchit:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_pcbcins:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_pcbcmis:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_pcdhit:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_pcdins:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_pcdmis:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_rcohit:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_rcomis:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_shchit:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_shcins:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_shcmis:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_cftob:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_cftbs:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_irtob:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_irtbs:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_jstob:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_jstbs:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_ccos:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_cccs:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_urltri:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_rurlrj:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_rwcdea:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_rfetca:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_numflu:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_numrwx:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_numrwd:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_val01:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_val02:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_val03:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_val04:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_val05:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_val06:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_val07:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_val08:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_val09:GAUGE:120:0:U");
|
|
push(@tmp, "DS:pagespeed" . $n . "_val10:GAUGE:120:0:U");
|
|
}
|
|
eval {
|
|
RRDs::create($rrd,
|
|
"--step=60",
|
|
@tmp,
|
|
"RRA:AVERAGE:0.5:1:1440",
|
|
"RRA:AVERAGE:0.5:30:336",
|
|
"RRA:AVERAGE:0.5:60:744",
|
|
@average,
|
|
"RRA:MIN:0.5:1:1440",
|
|
"RRA:MIN:0.5:30:336",
|
|
"RRA:MIN:0.5:60:744",
|
|
@min,
|
|
"RRA:MAX:0.5:1:1440",
|
|
"RRA:MAX:0.5:30:336",
|
|
"RRA:MAX:0.5:60:744",
|
|
@max,
|
|
"RRA:LAST:0.5:1:1440",
|
|
"RRA:LAST:0.5:30:336",
|
|
"RRA:LAST:0.5:60:744",
|
|
@last,
|
|
);
|
|
};
|
|
my $err = RRDs::error;
|
|
if($@ || $err) {
|
|
logger("$@") unless !$@;
|
|
if($err) {
|
|
logger("ERROR: while creating $rrd: $err");
|
|
if($err eq "RRDs::error") {
|
|
logger("... is the RRDtool Perl package installed?");
|
|
}
|
|
}
|
|
return;
|
|
}
|
|
}
|
|
|
|
$config->{pagespeed_hist} = ();
|
|
push(@{$config->{func_update}}, $package);
|
|
logger("$myself: Ok") if $debug;
|
|
}
|
|
|
|
sub pagespeed_update {
|
|
my $myself = (caller(0))[3];
|
|
my ($package, $config, $debug) = @_;
|
|
my $rrd = $config->{base_lib} . $package . ".rrd";
|
|
my $pagespeed = $config->{pagespeed};
|
|
|
|
my $str;
|
|
my $rrdata = "N";
|
|
|
|
my $n = 0;
|
|
foreach(my @pl = split(',', $pagespeed->{list})) {
|
|
my $url = trim($_);
|
|
my $ssl = "";
|
|
|
|
$ssl = "ssl_opts => {verify_hostname => 0}"
|
|
if lc($config->{accept_selfsigned_certs}) eq "y";
|
|
|
|
my $ua = LWP::UserAgent->new(timeout => 30, $ssl);
|
|
$ua->agent($config->{user_agent_id}) if $config->{user_agent_id} || "";
|
|
my $response = $ua->request(HTTP::Request->new('GET', $url));
|
|
|
|
if(!$response->is_success) {
|
|
logger("$myself: ERROR: Unable to connect to '$url'.");
|
|
logger("$myself: " . $response->status_line);
|
|
}
|
|
|
|
my $catim = 0;
|
|
my $cahit = 0;
|
|
my $camis = 0;
|
|
my $cabhit = 0;
|
|
my $cabmis = 0;
|
|
my $cafal = 0;
|
|
my $caexp = 0;
|
|
my $cains = 0;
|
|
my $cadel = 0;
|
|
my $caext = 0;
|
|
my $notca = 0;
|
|
my $fihit = 0;
|
|
my $fiins = 0;
|
|
my $fimis = 0;
|
|
my $lrhit = 0;
|
|
my $lrins = 0;
|
|
my $lrmis = 0;
|
|
my $mcahit = 0;
|
|
my $mcains = 0;
|
|
my $mcamis = 0;
|
|
my $mcbhit = 0;
|
|
my $mcbins = 0;
|
|
my $mcbmis = 0;
|
|
my $pcbchit = 0;
|
|
my $pcbcins = 0;
|
|
my $pcbcmis = 0;
|
|
my $pcdhit = 0;
|
|
my $pcdins = 0;
|
|
my $pcdmis = 0;
|
|
my $rcohit = 0;
|
|
my $rcomis = 0;
|
|
my $shchit = 0;
|
|
my $shcins = 0;
|
|
my $shcmis = 0;
|
|
my $cftob = 0;
|
|
my $cftbs = 0;
|
|
my $irtob = 0;
|
|
my $irtbs = 0;
|
|
my $jstob = 0;
|
|
my $jstbs = 0;
|
|
my $ccos = 0;
|
|
my $cccs = 0;
|
|
my $urltri = 0;
|
|
my $rurlrj = 0;
|
|
my $rwcdea = 0;
|
|
my $rfetca = 0;
|
|
my $numflu = 0;
|
|
my $numrwx = 0;
|
|
my $numrwd = 0;
|
|
|
|
foreach(split('\n', $response->content)) {
|
|
if(/^cache_time_us:\s+(\d+)$/) {
|
|
$str = $n . "catim";
|
|
$catim = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$catim = 0 unless $catim != $1;
|
|
$catim /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^cache_hits:\s+(\d+)$/) {
|
|
$str = $n . "cahit";
|
|
$cahit = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$cahit = 0 unless $cahit != $1;
|
|
$cahit /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^cache_misses:\s+(\d+)$/) {
|
|
$str = $n . "camis";
|
|
$camis = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$camis = 0 unless $camis != $1;
|
|
$camis /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^cache_backend_hits:\s+(\d+)$/) {
|
|
$str = $n . "cabhit";
|
|
$cabhit = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$cabhit = 0 unless $cabhit != $1;
|
|
$cabhit /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^cache_backend_misses:\s+(\d+)$/) {
|
|
$str = $n . "cabmis";
|
|
$cabmis = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$cabmis = 0 unless $cabmis != $1;
|
|
$cabmis /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^cache_fallbacks:\s+(\d+)$/) {
|
|
$str = $n . "cafal";
|
|
$cafal = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$cafal = 0 unless $cafal != $1;
|
|
$cafal /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^cache_expirations:\s+(\d+)$/) {
|
|
$str = $n . "caexp";
|
|
$caexp = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$caexp = 0 unless $caexp != $1;
|
|
$caexp /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^cache_inserts:\s+(\d+)$/) {
|
|
$str = $n . "cains";
|
|
$cains = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$cains = 0 unless $cains != $1;
|
|
$cains /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^cache_deletes:\s+(\d+)$/) {
|
|
$str = $n . "cadel";
|
|
$cadel = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$cadel = 0 unless $cadel != $1;
|
|
$cadel /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^cache_extensions:\s+(\d+)$/) {
|
|
$str = $n . "caext";
|
|
$caext = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$caext = 0 unless $caext != $1;
|
|
$caext /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^not_cacheable:\s+(\d+)$/) {
|
|
$str = $n . "notca";
|
|
$notca = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$notca = 0 unless $notca != $1;
|
|
$notca /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^file_cache_hits:\s+(\d+)$/) {
|
|
$str = $n . "fihit";
|
|
$fihit = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$fihit = 0 unless $fihit != $1;
|
|
$fihit /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^file_cache_inserts:\s+(\d+)$/) {
|
|
$str = $n . "fiins";
|
|
$fiins = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$fiins = 0 unless $fiins != $1;
|
|
$fiins /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^file_cache_misses:\s+(\d+)$/) {
|
|
$str = $n . "fimis";
|
|
$fimis = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$fimis = 0 unless $fimis != $1;
|
|
$fimis /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^lru_cache_hits:\s+(\d+)$/) {
|
|
$str = $n . "lrhit";
|
|
$lrhit = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$lrhit = 0 unless $lrhit != $1;
|
|
$lrhit /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^lru_cache_inserts:\s+(\d+)$/) {
|
|
$str = $n . "lrins";
|
|
$lrins = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$lrins = 0 unless $lrins != $1;
|
|
$lrins /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^lru_cache_misses:\s+(\d+)$/) {
|
|
$str = $n . "lrmis";
|
|
$lrmis = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$lrmis = 0 unless $lrmis != $1;
|
|
$lrmis /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^memcached_async_hits:\s+(\d+)$/) {
|
|
$str = $n . "mcahit";
|
|
$mcahit = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$mcahit = 0 unless $mcahit != $1;
|
|
$mcahit /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^memcached_async_inserts:\s+(\d+)$/) {
|
|
$str = $n . "mcains";
|
|
$mcains = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$mcains = 0 unless $mcains != $1;
|
|
$mcains /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^memcached_async_misses:\s+(\d+)$/) {
|
|
$str = $n . "mcamis";
|
|
$mcamis = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$mcamis = 0 unless $mcamis != $1;
|
|
$mcamis /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^memcached_blocking_hits:\s+(\d+)$/) {
|
|
$str = $n . "mcbhit";
|
|
$mcbhit = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$mcbhit = 0 unless $mcbhit != $1;
|
|
$mcbhit /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^memcached_blocking_inserts:\s+(\d+)$/) {
|
|
$str = $n . "mcbins";
|
|
$mcbins = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$mcbins = 0 unless $mcbins != $1;
|
|
$mcbins /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^memcached_blocking_misses:\s+(\d+)$/) {
|
|
$str = $n . "mcbmis";
|
|
$mcbmis = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$mcbmis = 0 unless $mcbmis != $1;
|
|
$mcbmis /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^pcache-cohorts-beacon_cohort_hits:\s+(\d+)$/) {
|
|
$str = $n . "pcbchit";
|
|
$pcbchit = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$pcbchit = 0 unless $pcbchit != $1;
|
|
$pcbchit /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^pcache-cohorts-beacon_cohort_inserts:\s+(\d+)$/) {
|
|
$str = $n . "pcbcins";
|
|
$pcbcins = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$pcbcins = 0 unless $pcbcins != $1;
|
|
$pcbcins /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^pcache-cohorts-beacon_cohort_misses:\s+(\d+)$/) {
|
|
$str = $n . "pcbcmis";
|
|
$pcbcmis = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$pcbcmis = 0 unless $pcbcmis != $1;
|
|
$pcbcmis /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^pcache-cohorts-dom_hits:\s+(\d+)$/) {
|
|
$str = $n . "pcdhit";
|
|
$pcdhit = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$pcdhit = 0 unless $pcdhit != $1;
|
|
$pcdhit /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^pcache-cohorts-dom_inserts:\s+(\d+)$/) {
|
|
$str = $n . "pcdins";
|
|
$pcdins = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$pcdins = 0 unless $pcdins != $1;
|
|
$pcdins /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^pcache-cohorts-dom_misses:\s+(\d+)$/) {
|
|
$str = $n . "pcdmis";
|
|
$pcdmis = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$pcdmis = 0 unless $pcdmis != $1;
|
|
$pcdmis /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^rewrite_cached_output_hits:\s+(\d+)$/) {
|
|
$str = $n . "rcohit";
|
|
$rcohit = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$rcohit = 0 unless $rcohit != $1;
|
|
$rcohit /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^rewrite_cached_output_misses:\s+(\d+)$/) {
|
|
$str = $n . "rcomis";
|
|
$rcomis = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$rcomis = 0 unless $rcomis != $1;
|
|
$rcomis /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^shm_cache_hits:\s+(\d+)$/) {
|
|
$str = $n . "shchit";
|
|
$shchit = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$shchit = 0 unless $shchit != $1;
|
|
$shchit /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^shm_cache_inserts:\s+(\d+)$/) {
|
|
$str = $n . "shcins";
|
|
$shcins = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$shcins = 0 unless $shcins != $1;
|
|
$shcins /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^shm_cache_misses:\s+(\d+)$/) {
|
|
$str = $n . "shcmis";
|
|
$shcmis = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$shcmis = 0 unless $shcmis != $1;
|
|
$shcmis /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^css_filter_total_original_bytes:\s+(\d+)$/) {
|
|
$cftob = $1;
|
|
chomp($cftob);
|
|
next;
|
|
}
|
|
if(/^css_filter_total_bytes_saved:\s+(\d+)$/) {
|
|
$cftbs = $1;
|
|
chomp($cftbs);
|
|
next;
|
|
}
|
|
if(/^image_rewrite_total_original_bytes:\s+(\d+)$/) {
|
|
$irtob = $1;
|
|
chomp($irtob);
|
|
next;
|
|
}
|
|
if(/^image_rewrite_total_bytes_saved:\s+(\d+)$/) {
|
|
$irtbs = $1;
|
|
chomp($irtbs);
|
|
next;
|
|
}
|
|
if(/^javascript_total_original_bytes:\s+(\d+)$/) {
|
|
$jstob = $1;
|
|
chomp($jstob);
|
|
next;
|
|
}
|
|
if(/^javascript_total_bytes_saved:\s+(\d+)$/) {
|
|
$jstbs = $1;
|
|
chomp($jstbs);
|
|
next;
|
|
}
|
|
if(/^compressed_cache_original_size:\s+(\d+)$/) {
|
|
$ccos = $1;
|
|
chomp($ccos);
|
|
next;
|
|
}
|
|
if(/^compressed_cache_compressed_size:\s+(\d+)$/) {
|
|
$cccs = $1;
|
|
chomp($cccs);
|
|
next;
|
|
}
|
|
if(/^url_trims:\s+(\d+)$/) {
|
|
$str = $n . "urltri";
|
|
$urltri = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$urltri = 0 unless $urltri != $1;
|
|
$urltri /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^resource_url_domain_rejections:\s+(\d+)$/) {
|
|
$str = $n . "rurlrj";
|
|
$rurlrj = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$shcmis = 0 unless $rurlrj != $1;
|
|
$rurlrj /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^rewrite_cached_output_missed_deadline:\s+(\d+)$/) {
|
|
$str = $n . "rwcdea";
|
|
$rwcdea = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$rwcdea = 0 unless $rwcdea != $1;
|
|
$rwcdea /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^resource_fetches_cached:\s+(\d+)$/) {
|
|
$str = $n . "rfetca";
|
|
$rfetca = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$rfetca = 0 unless $rfetca != $1;
|
|
$rfetca /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^num_flushes:\s+(\d+)$/) {
|
|
$str = $n . "numflu";
|
|
$numflu = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$numflu = 0 unless $numflu != $1;
|
|
$numflu /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^num_rewrites_executed:\s+(\d+)$/) {
|
|
$str = $n . "numrwx";
|
|
$numrwx = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$numrwx = 0 unless $numrwx != $1;
|
|
$numrwx /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
if(/^num_rewrites_dropped:\s+(\d+)$/) {
|
|
$str = $n . "numrwd";
|
|
$numrwd = $1 - ($config->{pagespeed_hist}->{$str} || 0);
|
|
$numrwd = 0 unless $numrwd != $1;
|
|
$numrwd /= 60;
|
|
$config->{pagespeed_hist}->{$str} = $1;
|
|
next;
|
|
}
|
|
}
|
|
$rrdata .= ":$catim:$cahit:$camis:$cabhit:$cabmis:$cafal:$caexp:$cains:$cadel:$caext:$notca:$fihit:$fiins:$fimis:$lrhit:$lrins:$lrmis:$mcahit:$mcains:$mcamis:$mcbhit:$mcbins:$mcbmis:$pcbchit:$pcbcins:$pcbcmis:$pcdhit:$pcdins:$pcdmis:$rcohit:$rcomis:$shchit:$shcins:$shcmis:$cftob:$cftbs:$irtob:$irtbs:$jstob:$jstbs:$ccos:$cccs:$urltri:$rurlrj:$rwcdea:$rfetca:$numflu:$numrwx:$numrwd:0:0:0:0:0:0:0:0:0:0";
|
|
$n++;
|
|
}
|
|
|
|
RRDs::update($rrd, $rrdata);
|
|
logger("$myself: $rrdata") if $debug;
|
|
my $err = RRDs::error;
|
|
logger("ERROR: while updating $rrd: $err") if $err;
|
|
}
|
|
|
|
sub pagespeed_cgi {
|
|
my ($package, $config, $cgi) = @_;
|
|
my @output;
|
|
|
|
my $pagespeed = $config->{pagespeed};
|
|
my @rigid = split(',', ($pagespeed->{rigid} || ""));
|
|
my @limit = split(',', ($pagespeed->{limit} || ""));
|
|
my $tf = $cgi->{tf};
|
|
my $colors = $cgi->{colors};
|
|
my $graph = $cgi->{graph};
|
|
my $silent = $cgi->{silent};
|
|
my $zoom = $config->{global_zoom};
|
|
my %rrd = (
|
|
'new' => \&RRDs::graphv,
|
|
'old' => \&RRDs::graph,
|
|
);
|
|
my $version = "new";
|
|
my @full_size_mode;
|
|
my $pic;
|
|
my $picz;
|
|
my $picz_width;
|
|
my $picz_height;
|
|
|
|
my $u = "";
|
|
my $width;
|
|
my $height;
|
|
my @extra;
|
|
my @riglim;
|
|
my @IMG;
|
|
my @IMGz;
|
|
my @tmp;
|
|
my @tmpz;
|
|
my @CDEF;
|
|
my $e;
|
|
my $e2;
|
|
my $n;
|
|
my $n2;
|
|
my $str;
|
|
my $err;
|
|
|
|
$version = "old" if $RRDs::VERSION < 1.3;
|
|
push(@full_size_mode, "--full-size-mode") if $RRDs::VERSION > 1.3;
|
|
my $rrd = $config->{base_lib} . $package . ".rrd";
|
|
my $title = $config->{graph_title}->{$package};
|
|
my $IMG_DIR = $config->{base_dir} . "/" . $config->{imgs_dir};
|
|
my $imgfmt_uc = uc($config->{image_format});
|
|
my $imgfmt_lc = lc($config->{image_format});
|
|
foreach my $i (split(',', $config->{rrdtool_extra_options} || "")) {
|
|
push(@extra, trim($i)) if trim($i);
|
|
}
|
|
|
|
$title = !$silent ? $title : "";
|
|
|
|
|
|
# text mode
|
|
#
|
|
if(lc($config->{iface_mode}) eq "text") {
|
|
if($title) {
|
|
push(@output, main::graph_header($title, 2));
|
|
push(@output, " <tr>\n");
|
|
push(@output, " <td>\n");
|
|
}
|
|
my (undef, undef, undef, $data) = RRDs::fetch("$rrd",
|
|
"--resolution=$tf->{res}",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"AVERAGE");
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while fetching $rrd: $err\n") if $err;
|
|
my $line0;
|
|
my $line1;
|
|
my $line2;
|
|
my $line3;
|
|
my $n2;
|
|
push(@output, " <pre style='font-size: 12px; color: $colors->{fg_color}';>\n");
|
|
push(@output, " ");
|
|
$line0 = " Cache Overview File cache LRU cache Memcached async Memcached blocking Pcache cohorts beacon Pcache cohorts dom Rewrite cached SHM cache CSS filter total Image rewrite total Javascript total Compressed cache";
|
|
for($n = 0; $n < scalar(my @pl = split(',', $pagespeed->{list})); $n++) {
|
|
my $l = trim($pl[$n]);
|
|
$line1 .= $line0;
|
|
$line3 .= "--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------";
|
|
$line2 .= " Hits Misses B.Hits Misses Fallba Expira Insert Delete Extens Notcac Hits Insert Misses Hits Insert Misses Hits Insert Misses Hits Insert Misses Hits Insert Misses Hits Insert Misses Hits Misses Hits Insert Misses Orig_bytes Save_Bytes Orig_bytes Save_bytes Orig_bytes Save_bytes Orig_size Comp_size";
|
|
|
|
my $i = length($line0);
|
|
push(@output, sprintf(sprintf("%${i}s", sprintf("Pagespeed: %s", $l))));
|
|
}
|
|
push(@output, "\n");
|
|
push(@output, " $line1\n");
|
|
push(@output, "Time$line2 \n");
|
|
push(@output, "----$line3 \n");
|
|
my $line;
|
|
my @row;
|
|
my $time;
|
|
my $from;
|
|
my $to;
|
|
for($n = 0, $time = $tf->{tb}; $n < ($tf->{tb} * $tf->{ts}); $n++) {
|
|
$line = @$data[$n];
|
|
$time = $time - (1 / $tf->{ts});
|
|
$from = 1;
|
|
push(@output, sprintf(" %2d$tf->{tc} ", $time));
|
|
for($n2 = 0; $n2 < scalar(my @pl = split(',', $pagespeed->{list})); $n2++) {
|
|
$from += $n2 * 59;
|
|
$to = $from + 59;
|
|
@row = @$line[$from..$to];
|
|
push(@output, sprintf(" %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %6d %10d %10d %10d %10d %10d %10d %9d %9d", @row));
|
|
}
|
|
push(@output, "\n");
|
|
}
|
|
push(@output, " </pre>\n");
|
|
if($title) {
|
|
push(@output, " </td>\n");
|
|
push(@output, " </tr>\n");
|
|
push(@output, main::graph_footer());
|
|
}
|
|
push(@output, " <br>\n");
|
|
return @output;
|
|
}
|
|
|
|
|
|
# graph mode
|
|
#
|
|
if($silent eq "yes" || $silent eq "imagetag") {
|
|
$zoom = 1; # force 'global_zoom' to 1 in Multihost viewer
|
|
$colors->{fg_color} = "#000000"; # visible color for text mode
|
|
$u = "_";
|
|
}
|
|
if($silent eq "imagetagbig") {
|
|
$zoom = 1; # force 'global_zoom' to 1 in Multihost viewer
|
|
$colors->{fg_color} = "#000000"; # visible color for text mode
|
|
$u = "";
|
|
}
|
|
my $global_zoom = "--zoom=" . $zoom;
|
|
|
|
for($n = 0; $n < scalar(my @pl = split(',', $pagespeed->{list})); $n++) {
|
|
for($n2 = 1; $n2 <= 8; $n2++) {
|
|
$str = $u . $package . $n . $n2 . "." . $tf->{when} . ".$imgfmt_lc";
|
|
push(@IMG, $str);
|
|
unlink("$IMG_DIR" . $str);
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
$str = $u . $package . $n . $n2 . "z." . $tf->{when} . ".$imgfmt_lc";
|
|
push(@IMGz, $str);
|
|
unlink("$IMG_DIR" . $str);
|
|
}
|
|
}
|
|
}
|
|
|
|
$e = 0;
|
|
foreach (my @pl = split(',', $pagespeed->{list})) {
|
|
my $l = trim($_);
|
|
if($e) {
|
|
push(@output, " <br>\n");
|
|
}
|
|
if($title) {
|
|
push(@output, main::graph_header($title, 2));
|
|
}
|
|
@riglim = @{setup_riglim($rigid[0], $limit[0])};
|
|
if($title) {
|
|
push(@output, " <tr>\n");
|
|
push(@output, " <td class='td-valign-top'>\n");
|
|
}
|
|
undef(@tmp);
|
|
undef(@tmpz);
|
|
undef(@CDEF);
|
|
push(@tmp, "LINE2:cahit#5F04B4:Hits");
|
|
push(@tmp, "GPRINT:cahit" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cahit" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cahit" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cahit" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:camis#EE44EE:Misses");
|
|
push(@tmp, "GPRINT:camis" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:camis" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:camis" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:camis" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:cabhit#4444EE:Backend hits");
|
|
push(@tmp, "GPRINT:cabhit" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cabhit" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cabhit" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cabhit" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:cabmis#44EEEE:Backend misses");
|
|
push(@tmp, "GPRINT:cabmis" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cabmis" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cabmis" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cabmis" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:cafal#EEEE44:Fallbacks");
|
|
push(@tmp, "GPRINT:cafal" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cafal" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cafal" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cafal" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:caexp#FFA500:Expirations");
|
|
push(@tmp, "GPRINT:caexp" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:caexp" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:caexp" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:caexp" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:cains#44EE44:Inserts");
|
|
push(@tmp, "GPRINT:cains" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cains" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cains" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cains" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:cadel#EE4444:Deletes");
|
|
push(@tmp, "GPRINT:cadel" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cadel" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cadel" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:cadel" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:caext#448844:Extensions");
|
|
push(@tmp, "GPRINT:caext" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:caext" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:caext" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:caext" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:notca#888888:Not cacheable");
|
|
push(@tmp, "GPRINT:notca" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:notca" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:notca" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:notca" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmpz, "LINE2:cahit#5F04B4:Hits");
|
|
push(@tmpz, "LINE2:camis#EE44EE:Misses");
|
|
push(@tmpz, "LINE2:cabhit#4444EE:Backend hits");
|
|
push(@tmpz, "LINE2:cabmis#44EEEE:Backend misses");
|
|
push(@tmpz, "LINE2:cafal#EEEE44:Fallbacks");
|
|
push(@tmpz, "LINE2:caexp#FFA500:Expirations");
|
|
push(@tmpz, "LINE2:cains#44EE44:Inserts");
|
|
push(@tmpz, "LINE2:cadel#EE4444:Deletes");
|
|
push(@tmpz, "LINE2:caext#448844:Extensions");
|
|
push(@tmpz, "LINE2:notca#888888:Not cacheable");
|
|
if(lc($config->{show_gaps}) eq "y") {
|
|
push(@tmp, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@tmpz, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@CDEF, "CDEF:wrongdata=allvalues,UN,INF,UNKN,IF");
|
|
}
|
|
|
|
($width, $height) = split('x', $config->{graph_size}->{main});
|
|
if($silent =~ /imagetag/) {
|
|
($width, $height) = split('x', $config->{graph_size}->{remote}) if $silent eq "imagetag";
|
|
($width, $height) = split('x', $config->{graph_size}->{main}) if $silent eq "imagetagbig";
|
|
@tmp = @tmpz;
|
|
}
|
|
$pic = $rrd{$version}->("$IMG_DIR" . "$IMG[$e * 8]",
|
|
"--title=$config->{graphs}->{_pagespeed1} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Values/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:cahit=$rrd:pagespeed" . $e . "_cahit:AVERAGE",
|
|
"DEF:camis=$rrd:pagespeed" . $e . "_camis:AVERAGE",
|
|
"DEF:cabhit=$rrd:pagespeed" . $e . "_cabhit:AVERAGE",
|
|
"DEF:cabmis=$rrd:pagespeed" . $e . "_cabmis:AVERAGE",
|
|
"DEF:cafal=$rrd:pagespeed" . $e . "_cafal:AVERAGE",
|
|
"DEF:caexp=$rrd:pagespeed" . $e . "_caexp:AVERAGE",
|
|
"DEF:cains=$rrd:pagespeed" . $e . "_cains:AVERAGE",
|
|
"DEF:cadel=$rrd:pagespeed" . $e . "_cadel:AVERAGE",
|
|
"DEF:caext=$rrd:pagespeed" . $e . "_caext:AVERAGE",
|
|
"DEF:notca=$rrd:pagespeed" . $e . "_notca:AVERAGE",
|
|
"CDEF:allvalues=cahit,camis,cabhit,cabmis,cafal,caexp,cains,cadel,caext,notca,+,+,+,+,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmp);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMG[$e * 8]: $err\n") if $err;
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
($width, $height) = split('x', $config->{graph_size}->{zoom});
|
|
$picz = $rrd{$version}->("$IMG_DIR" . "$IMGz[$e * 8]",
|
|
"--title=$config->{graphs}->{_pagespeed1} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Values/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@full_size_mode,
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:cahit=$rrd:pagespeed" . $e . "_cahit:AVERAGE",
|
|
"DEF:camis=$rrd:pagespeed" . $e . "_camis:AVERAGE",
|
|
"DEF:cabhit=$rrd:pagespeed" . $e . "_cabhit:AVERAGE",
|
|
"DEF:cabmis=$rrd:pagespeed" . $e . "_cabmis:AVERAGE",
|
|
"DEF:cafal=$rrd:pagespeed" . $e . "_cafal:AVERAGE",
|
|
"DEF:caexp=$rrd:pagespeed" . $e . "_caexp:AVERAGE",
|
|
"DEF:cains=$rrd:pagespeed" . $e . "_cains:AVERAGE",
|
|
"DEF:cadel=$rrd:pagespeed" . $e . "_cadel:AVERAGE",
|
|
"DEF:caext=$rrd:pagespeed" . $e . "_caext:AVERAGE",
|
|
"DEF:notca=$rrd:pagespeed" . $e . "_notca:AVERAGE",
|
|
"CDEF:allvalues=cahit,camis,cabhit,cabmis,cafal,caexp,cains,cadel,caext,notca,+,+,+,+,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmpz);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMGz[$e * 8]: $err\n") if $err;
|
|
}
|
|
$e2 = $e + 1;
|
|
if($title || ($silent =~ /imagetag/ && $graph =~ /pagespeed$e2/)) {
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
if(lc($config->{disable_javascript_void}) eq "y") {
|
|
push(@output, " " . picz_a_element(config => $config, IMGz => $IMGz[$e * 8], IMG => $IMG[$e * 8]) . "\n");
|
|
} else {
|
|
if($version eq "new") {
|
|
$picz_width = $picz->{image_width} * $zoom;
|
|
$picz_height = $picz->{image_height} * $zoom;
|
|
} else {
|
|
$picz_width = $width + 115;
|
|
$picz_height = $height + 100;
|
|
}
|
|
push(@output, " " . picz_js_a_element(width => $picz_width, height => $picz_height, config => $config, IMGz => $IMGz[$e * 8], IMG => $IMG[$e * 8]) . "\n");
|
|
}
|
|
} else {
|
|
push(@output, " " . img_element(config => $config, IMG => $IMG[$e * 8]) . "\n");
|
|
}
|
|
}
|
|
|
|
@riglim = @{setup_riglim($rigid[1], $limit[1])};
|
|
undef(@tmp);
|
|
undef(@tmpz);
|
|
undef(@CDEF);
|
|
push(@tmp, "LINE2:urltri#5F04B4:URL trims");
|
|
push(@tmp, "GPRINT:urltri" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:urltri" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:urltri" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:urltri" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:rurlrj#EE44EE:Res.URL dom.rej.");
|
|
push(@tmp, "GPRINT:rurlrj" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:rurlrj" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:rurlrj" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:rurlrj" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:rwcdea#4444EE:Rew.mis.deadline");
|
|
push(@tmp, "GPRINT:rwcdea" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:rwcdea" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:rwcdea" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:rwcdea" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:rfetca#44EEEE:Res.fetch.cached");
|
|
push(@tmp, "GPRINT:rfetca" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:rfetca" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:rfetca" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:rfetca" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:numflu#EEEE44:Num. of flushes");
|
|
push(@tmp, "GPRINT:numflu" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:numflu" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:numflu" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:numflu" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:numrwx#FFA500:Num.rew. executed");
|
|
push(@tmp, "GPRINT:numrwx" . ":LAST:Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:numrwx" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:numrwx" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:numrwx" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmp, "LINE2:numrwd#EE4444:Num.rew. dropped");
|
|
push(@tmp, "GPRINT:numrwd" . ":LAST: Current\\:%6.2lf");
|
|
push(@tmp, "GPRINT:numrwd" . ":AVERAGE: Average\\:%6.2lf");
|
|
push(@tmp, "GPRINT:numrwd" . ":MIN: Min\\:%6.2lf");
|
|
push(@tmp, "GPRINT:numrwd" . ":MAX: Max\\:%6.2lf\\n");
|
|
push(@tmpz, "LINE2:urltri#5F04B4:URL trims");
|
|
push(@tmpz, "LINE2:rurlrj#EE44EE:Resource URL dom. rejections");
|
|
push(@tmpz, "LINE2:rwcdea#4444EE:Rewrite cached mis. deadline");
|
|
push(@tmpz, "LINE2:rfetca#44EEEE:Resource fetches cached");
|
|
push(@tmpz, "LINE2:numflu#EEEE44:Number of flushes");
|
|
push(@tmpz, "LINE2:numrwx#FFA500:Number of rewrites executed");
|
|
push(@tmpz, "LINE2:numrwd#EE4444:Number of rewrites dropped");
|
|
if(lc($config->{show_gaps}) eq "y") {
|
|
push(@tmp, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@tmpz, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@CDEF, "CDEF:wrongdata=allvalues,UN,INF,UNKN,IF");
|
|
}
|
|
|
|
($width, $height) = split('x', $config->{graph_size}->{main});
|
|
if($silent =~ /imagetag/) {
|
|
($width, $height) = split('x', $config->{graph_size}->{remote}) if $silent eq "imagetag";
|
|
($width, $height) = split('x', $config->{graph_size}->{main}) if $silent eq "imagetagbig";
|
|
@tmp = @tmpz;
|
|
}
|
|
$pic = $rrd{$version}->("$IMG_DIR" . "$IMG[$e * 8 + 1]",
|
|
"--title=$config->{graphs}->{_pagespeed2} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Values/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:urltri=$rrd:pagespeed" . $e . "_urltri:AVERAGE",
|
|
"DEF:rurlrj=$rrd:pagespeed" . $e . "_rurlrj:AVERAGE",
|
|
"DEF:rwcdea=$rrd:pagespeed" . $e . "_rwcdea:AVERAGE",
|
|
"DEF:rfetca=$rrd:pagespeed" . $e . "_rfetca:AVERAGE",
|
|
"DEF:numflu=$rrd:pagespeed" . $e . "_numflu:AVERAGE",
|
|
"DEF:numrwx=$rrd:pagespeed" . $e . "_numrwx:AVERAGE",
|
|
"DEF:numrwd=$rrd:pagespeed" . $e . "_numrwd:AVERAGE",
|
|
"CDEF:allvalues=urltri,rurlrj,rwcdea,rfetca,numflu,numrwx,numrwd,+,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmp);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMG[$e * 8 + 1]: $err\n") if $err;
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
($width, $height) = split('x', $config->{graph_size}->{zoom});
|
|
$picz = $rrd{$version}->("$IMG_DIR" . "$IMGz[$e * 8 + 1]",
|
|
"--title=$config->{graphs}->{_pagespeed2} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Values/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@full_size_mode,
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:urltri=$rrd:pagespeed" . $e . "_urltri:AVERAGE",
|
|
"DEF:rurlrj=$rrd:pagespeed" . $e . "_rurlrj:AVERAGE",
|
|
"DEF:rwcdea=$rrd:pagespeed" . $e . "_rwcdea:AVERAGE",
|
|
"DEF:rfetca=$rrd:pagespeed" . $e . "_rfetca:AVERAGE",
|
|
"DEF:numflu=$rrd:pagespeed" . $e . "_numflu:AVERAGE",
|
|
"DEF:numrwx=$rrd:pagespeed" . $e . "_numrwx:AVERAGE",
|
|
"DEF:numrwd=$rrd:pagespeed" . $e . "_numrwd:AVERAGE",
|
|
"CDEF:allvalues=urltri,rurlrj,rwcdea,rfetca,numflu,numrwx,numrwd,+,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmpz);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMGz[$e * 8 + 1]: $err\n") if $err;
|
|
}
|
|
$e2 = $e + 2;
|
|
if($title || ($silent =~ /imagetag/ && $graph =~ /pagespeed$e2/)) {
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
if(lc($config->{disable_javascript_void}) eq "y") {
|
|
push(@output, " " . picz_a_element(config => $config, IMGz => $IMGz[$e * 8 + 1], IMG => $IMG[$e * 8 + 1]) . "\n");
|
|
} else {
|
|
if($version eq "new") {
|
|
$picz_width = $picz->{image_width} * $zoom;
|
|
$picz_height = $picz->{image_height} * $zoom;
|
|
} else {
|
|
$picz_width = $width + 115;
|
|
$picz_height = $height + 100;
|
|
}
|
|
push(@output, " " . picz_js_a_element(width => $picz_width, height => $picz_height, config => $config, IMGz => $IMGz[$e * 8 + 1], IMG => $IMG[$e * 8 + 1]) . "\n");
|
|
}
|
|
} else {
|
|
push(@output, " " . img_element(config => $config, IMG => $IMG[$e * 8 + 1]) . "\n");
|
|
}
|
|
}
|
|
|
|
@riglim = @{setup_riglim($rigid[2], $limit[2])};
|
|
undef(@tmp);
|
|
undef(@tmpz);
|
|
undef(@CDEF);
|
|
push(@tmp, "LINE2:cf#FFA500:CSS filter");
|
|
push(@tmp, "GPRINT:cf" . ":LAST: Current\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:cf" . ":AVERAGE: Average\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:cf" . ":MIN: Min\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:cf" . ":MAX: Max\\:%4.1lf%%\\n");
|
|
push(@tmp, "LINE2:ir#44EEEE:Image rewrite");
|
|
push(@tmp, "GPRINT:ir" . ":LAST: Current\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:ir" . ":AVERAGE: Average\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:ir" . ":MIN: Min\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:ir" . ":MAX: Max\\:%4.1lf%%\\n");
|
|
push(@tmp, "LINE2:js#44EE44:Javascript");
|
|
push(@tmp, "GPRINT:js" . ":LAST: Current\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:js" . ":AVERAGE: Average\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:js" . ":MIN: Min\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:js" . ":MAX: Max\\:%4.1lf%%\\n");
|
|
push(@tmp, "LINE2:cc#4444EE:Compressed cache");
|
|
push(@tmp, "GPRINT:cc" . ":LAST: Current\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:cc" . ":AVERAGE: Average\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:cc" . ":MIN: Min\\:%4.1lf%%");
|
|
push(@tmp, "GPRINT:cc" . ":MAX: Max\\:%4.1lf%%\\n");
|
|
push(@tmpz, "LINE2:cf#FFA500:CSS filter");
|
|
push(@tmpz, "LINE2:ir#44EEEE:Image rewrite");
|
|
push(@tmpz, "LINE2:js#44EE44:Javascript");
|
|
push(@tmpz, "LINE2:cc#4444EE:Compressed cache");
|
|
push(@CDEF, "CDEF:cf=cftbs,100,*,cftob,/");
|
|
push(@CDEF, "CDEF:ir=irtbs,100,*,irtob,/");
|
|
push(@CDEF, "CDEF:js=jstbs,100,*,jstob,/");
|
|
push(@CDEF, "CDEF:cc=cccs,100,*,ccos,/");
|
|
push(@tmp, "COMMENT: \\n");
|
|
if(lc($config->{show_gaps}) eq "y") {
|
|
push(@tmp, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@tmpz, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@CDEF, "CDEF:wrongdata=allvalues,UN,INF,UNKN,IF");
|
|
}
|
|
($width, $height) = split('x', $config->{graph_size}->{main});
|
|
$pic = $rrd{$version}->("$IMG_DIR" . "$IMG[$e * 8 + 2]",
|
|
"--title=$config->{graphs}->{_pagespeed3} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Percent (%)",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:cftob=$rrd:pagespeed" . $e . "_cftob:AVERAGE",
|
|
"DEF:cftbs=$rrd:pagespeed" . $e . "_cftbs:AVERAGE",
|
|
"DEF:irtob=$rrd:pagespeed" . $e . "_irtob:AVERAGE",
|
|
"DEF:irtbs=$rrd:pagespeed" . $e . "_irtbs:AVERAGE",
|
|
"DEF:jstob=$rrd:pagespeed" . $e . "_jstob:AVERAGE",
|
|
"DEF:jstbs=$rrd:pagespeed" . $e . "_jstbs:AVERAGE",
|
|
"DEF:ccos=$rrd:pagespeed" . $e . "_ccos:AVERAGE",
|
|
"DEF:cccs=$rrd:pagespeed" . $e . "_cccs:AVERAGE",
|
|
"CDEF:allvalues=cftob,cftbs,irtob,irtbs,jstob,jstbs,ccos,cccs,+,+,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmp);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMG[$e * 8 + 2]: $err\n") if $err;
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
($width, $height) = split('x', $config->{graph_size}->{zoom});
|
|
$picz = $rrd{$version}->("$IMG_DIR" . "$IMGz[$e * 8 + 2]",
|
|
"--title=$config->{graphs}->{_pagespeed3} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Percent (%)",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@full_size_mode,
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:cftob=$rrd:pagespeed" . $e . "_cftob:AVERAGE",
|
|
"DEF:cftbs=$rrd:pagespeed" . $e . "_cftbs:AVERAGE",
|
|
"DEF:irtob=$rrd:pagespeed" . $e . "_irtob:AVERAGE",
|
|
"DEF:irtbs=$rrd:pagespeed" . $e . "_irtbs:AVERAGE",
|
|
"DEF:jstob=$rrd:pagespeed" . $e . "_jstob:AVERAGE",
|
|
"DEF:jstbs=$rrd:pagespeed" . $e . "_jstbs:AVERAGE",
|
|
"DEF:ccos=$rrd:pagespeed" . $e . "_ccos:AVERAGE",
|
|
"DEF:cccs=$rrd:pagespeed" . $e . "_cccs:AVERAGE",
|
|
"CDEF:allvalues=cftob,cftbs,irtob,irtbs,jstob,jstbs,ccos,cccs,+,+,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmpz);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMGz[$e * 8 + 2]: $err\n") if $err;
|
|
}
|
|
$e2 = $e + 3;
|
|
if($title || ($silent =~ /imagetag/ && $graph =~ /pagespeed$e2/)) {
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
if(lc($config->{disable_javascript_void}) eq "y") {
|
|
push(@output, " " . picz_a_element(config => $config, IMGz => $IMGz[$e * 8 + 2], IMG => $IMG[$e * 8 + 2]) . "\n");
|
|
} else {
|
|
if($version eq "new") {
|
|
$picz_width = $picz->{image_width} * $zoom;
|
|
$picz_height = $picz->{image_height} * $zoom;
|
|
} else {
|
|
$picz_width = $width + 115;
|
|
$picz_height = $height + 100;
|
|
}
|
|
push(@output, " " . picz_js_a_element(width => $picz_width, height => $picz_height, config => $config, IMGz => $IMGz[$e * 8 + 2], IMG => $IMG[$e * 8 + 2]) . "\n");
|
|
}
|
|
} else {
|
|
push(@output, " " . img_element(config => $config, IMG => $IMG[$e * 8 + 2]) . "\n");
|
|
}
|
|
}
|
|
if($title) {
|
|
push(@output, " </td>\n");
|
|
push(@output, " <td class='td-valign-top'>\n");
|
|
}
|
|
|
|
@riglim = @{setup_riglim($rigid[3], $limit[3])};
|
|
undef(@tmp);
|
|
undef(@tmpz);
|
|
undef(@CDEF);
|
|
push(@tmp, "LINE2:mcahit#44EEEE:Async hits");
|
|
push(@tmp, "GPRINT:mcahit" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:mcains#EEEE44:Async inserts");
|
|
push(@tmp, "GPRINT:mcains" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:mcamis#EE44EE:Async misses");
|
|
push(@tmp, "GPRINT:mcamis" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:mcbhit#009999:Blocking hits");
|
|
push(@tmp, "GPRINT:mcbhit" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:mcbins#FFA500:Blocking inserts");
|
|
push(@tmp, "GPRINT:mcbins" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:mcbmis#5F04B4:Blocking misses");
|
|
push(@tmp, "GPRINT:mcbmis" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmpz, "LINE2:mcahit#44EEEE:Async hits");
|
|
push(@tmpz, "LINE2:mcains#EEEE44:Async inserts");
|
|
push(@tmpz, "LINE2:mcamis#EE44EE:Async misses");
|
|
push(@tmpz, "LINE2:mcbhit#009999:Blocking hits");
|
|
push(@tmpz, "LINE2:mcbins#FFA500:Blocking inserts");
|
|
push(@tmpz, "LINE2:mcbmis#5F04B4:Blocking misses");
|
|
if(lc($config->{show_gaps}) eq "y") {
|
|
push(@tmp, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@tmpz, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@CDEF, "CDEF:wrongdata=allvalues,UN,INF,UNKN,IF");
|
|
}
|
|
($width, $height) = split('x', $config->{graph_size}->{small});
|
|
$pic = $rrd{$version}->("$IMG_DIR" . "$IMG[$e * 8 + 3]",
|
|
"--title=$config->{graphs}->{_pagespeed4} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Values/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$cgi->{version12_small}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:mcahit=$rrd:pagespeed" . $e . "_mcahit:AVERAGE",
|
|
"DEF:mcains=$rrd:pagespeed" . $e . "_mcains:AVERAGE",
|
|
"DEF:mcamis=$rrd:pagespeed" . $e . "_mcamis:AVERAGE",
|
|
"DEF:mcbhit=$rrd:pagespeed" . $e . "_mcbhit:AVERAGE",
|
|
"DEF:mcbins=$rrd:pagespeed" . $e . "_mcbins:AVERAGE",
|
|
"DEF:mcbmis=$rrd:pagespeed" . $e . "_mcbmis:AVERAGE",
|
|
"CDEF:allvalues=mcbhit,mcbins,mcbmis,mcahit,mcains,mcamis,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmp);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMG[$e * 8 + 3]: $err\n") if $err;
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
($width, $height) = split('x', $config->{graph_size}->{zoom});
|
|
$picz = $rrd{$version}->("$IMG_DIR" . "$IMGz[$e * 8 + 3]",
|
|
"--title=$config->{graphs}->{_pagespeed4} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Values/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@full_size_mode,
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$cgi->{version12_small}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:mcahit=$rrd:pagespeed" . $e . "_mcahit:AVERAGE",
|
|
"DEF:mcains=$rrd:pagespeed" . $e . "_mcains:AVERAGE",
|
|
"DEF:mcamis=$rrd:pagespeed" . $e . "_mcamis:AVERAGE",
|
|
"DEF:mcbhit=$rrd:pagespeed" . $e . "_mcbhit:AVERAGE",
|
|
"DEF:mcbins=$rrd:pagespeed" . $e . "_mcbins:AVERAGE",
|
|
"DEF:mcbmis=$rrd:pagespeed" . $e . "_mcbmis:AVERAGE",
|
|
"CDEF:allvalues=mcbhit,mcbins,mcbmis,mcahit,mcains,mcamis,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmpz);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMGz[$e * 8 + 3]: $err\n") if $err;
|
|
}
|
|
$e2 = $e + 4;
|
|
if($title || ($silent =~ /imagetag/ && $graph =~ /pagespeed$e2/)) {
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
if(lc($config->{disable_javascript_void}) eq "y") {
|
|
push(@output, " " . picz_a_element(config => $config, IMGz => $IMGz[$e * 8 + 3], IMG => $IMG[$e * 8 + 3]) . "\n");
|
|
} else {
|
|
if($version eq "new") {
|
|
$picz_width = $picz->{image_width} * $zoom;
|
|
$picz_height = $picz->{image_height} * $zoom;
|
|
} else {
|
|
$picz_width = $width + 115;
|
|
$picz_height = $height + 100;
|
|
}
|
|
push(@output, " " . picz_js_a_element(width => $picz_width, height => $picz_height, config => $config, IMGz => $IMGz[$e * 8 + 3], IMG => $IMG[$e * 8 + 3]) . "\n");
|
|
}
|
|
} else {
|
|
push(@output, " " . img_element(config => $config, IMG => $IMG[$e * 8 + 3]) . "\n");
|
|
}
|
|
}
|
|
|
|
@riglim = @{setup_riglim($rigid[4], $limit[4])};
|
|
undef(@tmp);
|
|
undef(@tmpz);
|
|
undef(@CDEF);
|
|
push(@tmp, "LINE2:pcbchit#44EEEE:Beacon hits");
|
|
push(@tmp, "GPRINT:pcbchit" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:pcbcins#EEEE44:beacon inserts");
|
|
push(@tmp, "GPRINT:pcbcins" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:pcbcmis#EE44EE:beacon misses");
|
|
push(@tmp, "GPRINT:pcbcmis" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:pcdhit#009999:Dom hits");
|
|
push(@tmp, "GPRINT:pcdhit" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:pcdins#FFA500:Dom inserts");
|
|
push(@tmp, "GPRINT:pcdins" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:pcdmis#5F04B4:Dom misses");
|
|
push(@tmp, "GPRINT:pcdmis" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmpz, "LINE2:pcdhit#44EEEE:Beacon hits");
|
|
push(@tmpz, "LINE2:pcdins#EEEE44:Beacon inserts");
|
|
push(@tmpz, "LINE2:pcdmis#EE44EE:Beacon misses");
|
|
push(@tmpz, "LINE2:pcbchit#009999:Dom hits");
|
|
push(@tmpz, "LINE2:pcbcins#FFA500:Dom inserts");
|
|
push(@tmpz, "LINE2:pcbcmis#5F04B4:Dom misses");
|
|
if(lc($config->{show_gaps}) eq "y") {
|
|
push(@tmp, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@tmpz, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@CDEF, "CDEF:wrongdata=allvalues,UN,INF,UNKN,IF");
|
|
}
|
|
($width, $height) = split('x', $config->{graph_size}->{small});
|
|
$pic = $rrd{$version}->("$IMG_DIR" . "$IMG[$e * 8 + 4]",
|
|
"--title=$config->{graphs}->{_pagespeed5} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Values/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$cgi->{version12_small}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:pcbchit=$rrd:pagespeed" . $e . "_pcbchit:AVERAGE",
|
|
"DEF:pcbcins=$rrd:pagespeed" . $e . "_pcbcins:AVERAGE",
|
|
"DEF:pcbcmis=$rrd:pagespeed" . $e . "_pcbcmis:AVERAGE",
|
|
"DEF:pcdhit=$rrd:pagespeed" . $e . "_pcdhit:AVERAGE",
|
|
"DEF:pcdins=$rrd:pagespeed" . $e . "_pcdins:AVERAGE",
|
|
"DEF:pcdmis=$rrd:pagespeed" . $e . "_pcdmis:AVERAGE",
|
|
"CDEF:allvalues=pcbchit,pcbcins,pcbcmis,pcdhit,pcdins,pcdmis,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmp);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMG[$e * 8 + 4]: $err\n") if $err;
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
($width, $height) = split('x', $config->{graph_size}->{zoom});
|
|
$picz = $rrd{$version}->("$IMG_DIR" . "$IMGz[$e * 8 + 4]",
|
|
"--title=$config->{graphs}->{_pagespeed5} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Values/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@full_size_mode,
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$cgi->{version12_small}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:pcbchit=$rrd:pagespeed" . $e . "_pcbchit:AVERAGE",
|
|
"DEF:pcbcins=$rrd:pagespeed" . $e . "_pcbcins:AVERAGE",
|
|
"DEF:pcbcmis=$rrd:pagespeed" . $e . "_pcbcmis:AVERAGE",
|
|
"DEF:pcdhit=$rrd:pagespeed" . $e . "_pcdhit:AVERAGE",
|
|
"DEF:pcdins=$rrd:pagespeed" . $e . "_pcdins:AVERAGE",
|
|
"DEF:pcdmis=$rrd:pagespeed" . $e . "_pcdmis:AVERAGE",
|
|
"CDEF:allvalues=pcbchit,pcbcins,pcbcmis,pcdhit,pcdins,pcdmis,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmpz);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMGz[$e * 8 + 4]: $err\n") if $err;
|
|
}
|
|
$e2 = $e + 5;
|
|
if($title || ($silent =~ /imagetag/ && $graph =~ /pagespeed$e2/)) {
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
if(lc($config->{disable_javascript_void}) eq "y") {
|
|
push(@output, " " . picz_a_element(config => $config, IMGz => $IMGz[$e * 8 + 4], IMG => $IMG[$e * 8 + 4]) . "\n");
|
|
} else {
|
|
if($version eq "new") {
|
|
$picz_width = $picz->{image_width} * $zoom;
|
|
$picz_height = $picz->{image_height} * $zoom;
|
|
} else {
|
|
$picz_width = $width + 115;
|
|
$picz_height = $height + 100;
|
|
}
|
|
push(@output, " " . picz_js_a_element(width => $picz_width, height => $picz_height, config => $config, IMGz => $IMGz[$e * 8 + 4], IMG => $IMG[$e * 8 + 4]) . "\n");
|
|
}
|
|
} else {
|
|
push(@output, " " . img_element(config => $config, IMG => $IMG[$e * 8 + 4]) . "\n");
|
|
}
|
|
}
|
|
|
|
@riglim = @{setup_riglim($rigid[5], $limit[5])};
|
|
undef(@tmp);
|
|
undef(@tmpz);
|
|
undef(@CDEF);
|
|
push(@tmp, "LINE2:rcohit#44EEEE:Rewrite c.o. hits");
|
|
push(@tmp, "GPRINT:rcohit" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:rcomis#EE44EE:Rewrite c.o. misses");
|
|
push(@tmp, "GPRINT:rcomis" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:shchit#009999:SHM cache hits");
|
|
push(@tmp, "GPRINT:shchit" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:shcins#FFA500:SHM cache inserts");
|
|
push(@tmp, "GPRINT:shcins" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:shcmis#5F04B4:SHM cache misses");
|
|
push(@tmp, "GPRINT:shcmis" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmpz, "LINE2:rcohit#44EEEE:Rewrite c.o. hits");
|
|
push(@tmpz, "LINE2:rcomis#EE44EE:Rewrite c.o. misses");
|
|
push(@tmpz, "LINE2:shchit#009999:SHM cache hits");
|
|
push(@tmpz, "LINE2:shcins#FFA500:SHM cache inserts");
|
|
push(@tmpz, "LINE2:shcmis#5F04B4:SHM cache misses");
|
|
if(lc($config->{show_gaps}) eq "y") {
|
|
push(@tmp, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@tmpz, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@CDEF, "CDEF:wrongdata=allvalues,UN,INF,UNKN,IF");
|
|
}
|
|
($width, $height) = split('x', $config->{graph_size}->{small});
|
|
$pic = $rrd{$version}->("$IMG_DIR" . "$IMG[$e * 8 + 5]",
|
|
"--title=$config->{graphs}->{_pagespeed6} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Values/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$cgi->{version12_small}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:rcohit=$rrd:pagespeed" . $e . "_rcohit:AVERAGE",
|
|
"DEF:rcomis=$rrd:pagespeed" . $e . "_rcomis:AVERAGE",
|
|
"DEF:shchit=$rrd:pagespeed" . $e . "_shchit:AVERAGE",
|
|
"DEF:shcins=$rrd:pagespeed" . $e . "_shcins:AVERAGE",
|
|
"DEF:shcmis=$rrd:pagespeed" . $e . "_shcmis:AVERAGE",
|
|
"CDEF:allvalues=rcohit,rcomis,shchit,shcins,shcmis,+,+,+,+",
|
|
@CDEF,
|
|
@tmp);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMG[$e * 8 + 5]: $err\n") if $err;
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
($width, $height) = split('x', $config->{graph_size}->{zoom});
|
|
$picz = $rrd{$version}->("$IMG_DIR" . "$IMGz[$e * 8 + 5]",
|
|
"--title=$config->{graphs}->{_pagespeed6} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Values/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@full_size_mode,
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$cgi->{version12_small}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:rcohit=$rrd:pagespeed" . $e . "_rcohit:AVERAGE",
|
|
"DEF:rcomis=$rrd:pagespeed" . $e . "_rcomis:AVERAGE",
|
|
"DEF:shchit=$rrd:pagespeed" . $e . "_shchit:AVERAGE",
|
|
"DEF:shcins=$rrd:pagespeed" . $e . "_shcins:AVERAGE",
|
|
"DEF:shcmis=$rrd:pagespeed" . $e . "_shcmis:AVERAGE",
|
|
"CDEF:allvalues=rcohit,rcomis,shchit,shcins,shcmis,+,+,+,+",
|
|
@CDEF,
|
|
@tmpz);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMGz[$e * 8 + 5]: $err\n") if $err;
|
|
}
|
|
$e2 = $e + 6;
|
|
if($title || ($silent =~ /imagetag/ && $graph =~ /pagespeed$e2/)) {
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
if(lc($config->{disable_javascript_void}) eq "y") {
|
|
push(@output, " " . picz_a_element(config => $config, IMGz => $IMGz[$e * 8 + 5], IMG => $IMG[$e * 8 + 5]) . "\n");
|
|
} else {
|
|
if($version eq "new") {
|
|
$picz_width = $picz->{image_width} * $zoom;
|
|
$picz_height = $picz->{image_height} * $zoom;
|
|
} else {
|
|
$picz_width = $width + 115;
|
|
$picz_height = $height + 100;
|
|
}
|
|
push(@output, " " . picz_js_a_element(width => $picz_width, height => $picz_height, config => $config, IMGz => $IMGz[$e * 8 + 5], IMG => $IMG[$e * 8 + 5]) . "\n");
|
|
}
|
|
} else {
|
|
push(@output, " " . img_element(config => $config, IMG => $IMG[$e * 8 + 5]) . "\n");
|
|
}
|
|
}
|
|
|
|
@riglim = @{setup_riglim($rigid[6], $limit[6])};
|
|
undef(@tmp);
|
|
undef(@tmpz);
|
|
undef(@CDEF);
|
|
push(@tmp, "LINE2:fihit#44EEEE:LRU cache hits");
|
|
push(@tmp, "GPRINT:fihit" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:fiins#EEEE44:LRU cache inserts");
|
|
push(@tmp, "GPRINT:fiins" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:fimis#EE44EE:LRU cache misses");
|
|
push(@tmp, "GPRINT:fimis" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:lrhit#009999:File cache hits");
|
|
push(@tmp, "GPRINT:lrhit" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:lrins#FFA500:File cache inserts");
|
|
push(@tmp, "GPRINT:lrins" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmp, "LINE2:lrmis#5F04B4:File cache misses");
|
|
push(@tmp, "GPRINT:lrmis" . ":LAST: Current\\:%5.1lf\\n");
|
|
push(@tmpz, "LINE2:fihit#44EEEE:LRU cache hits");
|
|
push(@tmpz, "LINE2:fiins#EEEE44:LRU cache inserts");
|
|
push(@tmpz, "LINE2:fimis#EE44EE:LRU cache misses");
|
|
push(@tmpz, "LINE2:lrhit#009999:File cache hits");
|
|
push(@tmpz, "LINE2:lrins#FFA500:File cache inserts");
|
|
push(@tmpz, "LINE2:lrmis#5F04B4:File cache misses");
|
|
if(lc($config->{show_gaps}) eq "y") {
|
|
push(@tmp, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@tmpz, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@CDEF, "CDEF:wrongdata=allvalues,UN,INF,UNKN,IF");
|
|
}
|
|
($width, $height) = split('x', $config->{graph_size}->{small});
|
|
$pic = $rrd{$version}->("$IMG_DIR" . "$IMG[$e * 8 + 6]",
|
|
"--title=$config->{graphs}->{_pagespeed7} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Values/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$cgi->{version12_small}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:fihit=$rrd:pagespeed" . $e . "_fihit:AVERAGE",
|
|
"DEF:fiins=$rrd:pagespeed" . $e . "_fiins:AVERAGE",
|
|
"DEF:fimis=$rrd:pagespeed" . $e . "_fimis:AVERAGE",
|
|
"DEF:lrhit=$rrd:pagespeed" . $e . "_lrhit:AVERAGE",
|
|
"DEF:lrins=$rrd:pagespeed" . $e . "_lrins:AVERAGE",
|
|
"DEF:lrmis=$rrd:pagespeed" . $e . "_lrmis:AVERAGE",
|
|
"CDEF:allvalues=fihit,fiins,fimis,lrhit,lrins,lrmis,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmp);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMG[$e * 8 + 6]: $err\n") if $err;
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
($width, $height) = split('x', $config->{graph_size}->{zoom});
|
|
$picz = $rrd{$version}->("$IMG_DIR" . "$IMGz[$e * 8 + 6]",
|
|
"--title=$config->{graphs}->{_pagespeed7} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Value/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@full_size_mode,
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$cgi->{version12_small}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:fihit=$rrd:pagespeed" . $e . "_fihit:AVERAGE",
|
|
"DEF:fiins=$rrd:pagespeed" . $e . "_fiins:AVERAGE",
|
|
"DEF:fimis=$rrd:pagespeed" . $e . "_fimis:AVERAGE",
|
|
"DEF:lrhit=$rrd:pagespeed" . $e . "_lrhit:AVERAGE",
|
|
"DEF:lrins=$rrd:pagespeed" . $e . "_lrins:AVERAGE",
|
|
"DEF:lrmis=$rrd:pagespeed" . $e . "_lrmis:AVERAGE",
|
|
"CDEF:allvalues=fihit,fiins,fimis,lrhit,lrins,lrmis,+,+,+,+,+",
|
|
@CDEF,
|
|
@tmpz);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMGz[$e * 8 + 6]: $err\n") if $err;
|
|
}
|
|
$e2 = $e + 7;
|
|
if($title || ($silent =~ /imagetag/ && $graph =~ /pagespeed$e2/)) {
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
if(lc($config->{disable_javascript_void}) eq "y") {
|
|
push(@output, " " . picz_a_element(config => $config, IMGz => $IMGz[$e * 8 + 6], IMG => $IMG[$e * 8 + 6]) . "\n");
|
|
} else {
|
|
if($version eq "new") {
|
|
$picz_width = $picz->{image_width} * $zoom;
|
|
$picz_height = $picz->{image_height} * $zoom;
|
|
} else {
|
|
$picz_width = $width + 115;
|
|
$picz_height = $height + 100;
|
|
}
|
|
push(@output, " " . picz_js_a_element(width => $picz_width, height => $picz_height, config => $config, IMGz => $IMGz[$e * 8 + 6], IMG => $IMG[$e * 8 + 6]) . "\n");
|
|
}
|
|
} else {
|
|
push(@output, " " . img_element(config => $config, IMG => $IMG[$e * 8 + 6]) . "\n");
|
|
}
|
|
}
|
|
|
|
@riglim = @{setup_riglim($rigid[7], $limit[7])};
|
|
undef(@tmp);
|
|
undef(@tmpz);
|
|
undef(@CDEF);
|
|
push(@tmp, "LINE2:catim#44EEEE:Cache time");
|
|
push(@tmp, "GPRINT:catim" . ":LAST: Current\\:%6.0lf\\n");
|
|
push(@tmpz, "LINE2:catim#44EEEE:Cache time");
|
|
if(lc($config->{show_gaps}) eq "y") {
|
|
push(@tmp, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@tmpz, "AREA:wrongdata#$colors->{gap}:");
|
|
push(@CDEF, "CDEF:wrongdata=allvalues,UN,INF,UNKN,IF");
|
|
}
|
|
($width, $height) = split('x', $config->{graph_size}->{small});
|
|
$pic = $rrd{$version}->("$IMG_DIR" . "$IMG[$e * 8 + 7]",
|
|
"--title=$config->{graphs}->{_pagespeed8} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Microseconds/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$cgi->{version12_small}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:catim=$rrd:pagespeed" . $e . "_catim:AVERAGE",
|
|
"CDEF:allvalues=catim",
|
|
@CDEF,
|
|
@tmp);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMG[$e * 8 + 7]: $err\n") if $err;
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
($width, $height) = split('x', $config->{graph_size}->{zoom});
|
|
$picz = $rrd{$version}->("$IMG_DIR" . "$IMGz[$e * 8 + 7]",
|
|
"--title=$config->{graphs}->{_pagespeed8} ($tf->{nwhen}$tf->{twhen})",
|
|
"--start=-$tf->{nwhen}$tf->{twhen}",
|
|
"--imgformat=$imgfmt_uc",
|
|
"--vertical-label=Microseconds/s",
|
|
"--width=$width",
|
|
"--height=$height",
|
|
@full_size_mode,
|
|
@extra,
|
|
@riglim,
|
|
$global_zoom,
|
|
@{$cgi->{version12}},
|
|
@{$cgi->{version12_small}},
|
|
@{$colors->{graph_colors}},
|
|
"DEF:catim=$rrd:pagespeed" . $e . "_catim:AVERAGE",
|
|
"CDEF:allvalues=catim",
|
|
@CDEF,
|
|
@tmpz);
|
|
$err = RRDs::error;
|
|
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMGz[$e * 8 + 7]: $err\n") if $err;
|
|
}
|
|
$e2 = $e + 8;
|
|
if($title || ($silent =~ /imagetag/ && $graph =~ /pagespeed$e2/)) {
|
|
if(lc($config->{enable_zoom}) eq "y") {
|
|
if(lc($config->{disable_javascript_void}) eq "y") {
|
|
push(@output, " " . picz_a_element(config => $config, IMGz => $IMGz[$e * 8 + 7], IMG => $IMG[$e * 8 + 7]) . "\n");
|
|
} else {
|
|
if($version eq "new") {
|
|
$picz_width = $picz->{image_width} * $zoom;
|
|
$picz_height = $picz->{image_height} * $zoom;
|
|
} else {
|
|
$picz_width = $width + 115;
|
|
$picz_height = $height + 100;
|
|
}
|
|
push(@output, " " . picz_js_a_element(width => $picz_width, height => $picz_height, config => $config, IMGz => $IMGz[$e * 8 + 7], IMG => $IMG[$e * 8 + 7]) . "\n");
|
|
}
|
|
} else {
|
|
push(@output, " " . img_element(config => $config, IMG => $IMG[$e * 8 + 7]) . "\n");
|
|
}
|
|
}
|
|
|
|
if($title) {
|
|
push(@output, " </td>\n");
|
|
push(@output, " </tr>\n");
|
|
|
|
push(@output, " <tr>\n");
|
|
push(@output, " <td class='td-title' colspan='2'>\n");
|
|
push(@output, " <font size='-1'>\n");
|
|
push(@output, " <b> <a href='" . $l . "'>$l</a></b>\n");
|
|
push(@output, " </font>\n");
|
|
push(@output, " </td>\n");
|
|
push(@output, " </tr>\n");
|
|
push(@output, main::graph_footer());
|
|
}
|
|
$e++;
|
|
}
|
|
push(@output, " <br>\n");
|
|
return @output;
|
|
}
|
|
|
|
1;
|