added ZFS iostat per pool in 'zfs.pm' #190

This commit is contained in:
Jordi Sanfeliu 2018-03-23 11:29:07 +01:00
parent 6b0913143a
commit 6f8ffd0d2e
3 changed files with 219 additions and 27 deletions

View File

@ -10,6 +10,8 @@
and the third load averages to obtain a more symmetric curve and a sooner and the third load averages to obtain a more symmetric curve and a sooner
cancellation of the alert. cancellation of the alert.
(suggested by Michael Tosch) (suggested by Michael Tosch)
- Added two new graphs (operations and bandwidth) for each pool in 'zfs.pm' to
show iostats. [#190]
- 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

@ -82,10 +82,10 @@ sub zfs_init {
push(@tmp, "DS:zfs" . $n . "_usnap:GAUGE:120:0:U"); push(@tmp, "DS:zfs" . $n . "_usnap:GAUGE:120:0:U");
push(@tmp, "DS:zfs" . $n . "_cap:GAUGE:120:0:100"); push(@tmp, "DS:zfs" . $n . "_cap:GAUGE:120:0:100");
push(@tmp, "DS:zfs" . $n . "_fra:GAUGE:120:0:100"); push(@tmp, "DS:zfs" . $n . "_fra:GAUGE:120:0:100");
push(@tmp, "DS:zfs" . $n . "_val1:GAUGE:120:0:U"); push(@tmp, "DS:zfs" . $n . "_oper:GAUGE:120:0:U");
push(@tmp, "DS:zfs" . $n . "_val2:GAUGE:120:0:U"); push(@tmp, "DS:zfs" . $n . "_opew:GAUGE:120:0:U");
push(@tmp, "DS:zfs" . $n . "_val3:GAUGE:120:0:U"); push(@tmp, "DS:zfs" . $n . "_banr:GAUGE:120:0:U");
push(@tmp, "DS:zfs" . $n . "_val4:GAUGE:120:0:U"); push(@tmp, "DS:zfs" . $n . "_banw:GAUGE:120:0:U");
push(@tmp, "DS:zfs" . $n . "_val5:GAUGE:120:0:U"); push(@tmp, "DS:zfs" . $n . "_val5:GAUGE:120:0:U");
} }
eval { eval {
@ -145,6 +145,17 @@ sub zfs_init {
} }
} }
# Since 3.11.0 four new values were included (operations r/w and
# bandwidth r/w).
for($n = 0; $n < $zfs->{max_pools}; $n++) {
RRDs::tune($rrd,
"--data-source-rename=zfs" . $n . "_val1:zfs" . $n . "_oper",
"--data-source-rename=zfs" . $n . "_val2:zfs" . $n . "_opew",
"--data-source-rename=zfs" . $n . "_val3:zfs" . $n . "_banr",
"--data-source-rename=zfs" . $n . "_val4:zfs" . $n . "_banw",
);
}
$config->{zfs_hist} = (); $config->{zfs_hist} = ();
push(@{$config->{func_update}}, $package); push(@{$config->{func_update}}, $package);
logger("$myself: Ok") if $debug; logger("$myself: Ok") if $debug;
@ -247,10 +258,10 @@ sub zfs_update {
my $usnap = 0; my $usnap = 0;
my $cap = 0; my $cap = 0;
my $fra = 0; my $fra = 0;
my $val1 = 0; my $oper = 0;
my $val2 = 0; my $opew = 0;
my $val3 = 0; my $banr = 0;
my $val4 = 0; my $banw = 0;
my $val5 = 0; my $val5 = 0;
my $pool = (split(',', $zfs->{list}))[$n] || ""; my $pool = (split(',', $zfs->{list}))[$n] || "";
@ -271,9 +282,11 @@ sub zfs_update {
} }
$cap =~ s/%//; $cap =~ s/%//;
$fra =~ s/[%-]//g; $fra = $fra || 0; $fra =~ s/[%-]//g; $fra = $fra || 0;
@zpool = split(' ', `zpool iostat -Hp $pool` || "");
(undef, undef, undef, $oper, $opew, $banr, $banw) = @zpool;
} }
$rrdata .= ":$free:$udata:$usnap:$cap:$fra:0:0:0:0:0"; $rrdata .= ":$free:$udata:$usnap:$cap:$fra:$oper:$opew:$banr:$banw:0";
} }
RRDs::update($rrd, $rrdata); RRDs::update($rrd, $rrdata);
@ -417,19 +430,16 @@ sub zfs_cgi {
"$IMG_DIR" . "$IMG3z"); "$IMG_DIR" . "$IMG3z");
} }
for($n = 0; $n < scalar(my @pl = split(',', $zfs->{list})); $n++) { for($n = 0; $n < scalar(my @pl = split(',', $zfs->{list})); $n++) {
$str = $u . $package . ($n + 4) . "1." . $tf->{when} . ".$imgfmt_lc"; my $n2;
push(@IMG, $str); for($n2 = 1; $n2 < 5; $n2++) {
unlink("$IMG_DIR" . $str); $str = $u . $package . ($n + 4) . $n2 . "." . $tf->{when} . ".$imgfmt_lc";
$str = $u . $package . ($n + 4) . "2." . $tf->{when} . ".$imgfmt_lc"; push(@IMG, $str);
push(@IMG, $str);
unlink("$IMG_DIR" . $str);
if(lc($config->{enable_zoom}) eq "y") {
$str = $u . $package . ($n + 4) . "1z." . $tf->{when} . ".$imgfmt_lc";
push(@IMGz, $str);
unlink("$IMG_DIR" . $str);
$str = $u . $package . ($n + 4) . "2z." . $tf->{when} . ".$imgfmt_lc";
push(@IMGz, $str);
unlink("$IMG_DIR" . $str); unlink("$IMG_DIR" . $str);
if(lc($config->{enable_zoom}) eq "y") {
$str = $u . $package . ($n + 4) . $n2 . "z." . $tf->{when} . ".$imgfmt_lc";
push(@IMGz, $str);
unlink("$IMG_DIR" . $str);
}
} }
} }
@ -840,10 +850,6 @@ sub zfs_cgi {
} }
$e++; $e++;
if($title) {
push(@output, " </td>\n");
push(@output, " <td bgcolor='" . $colors->{title_bg_color} . "'>\n");
}
@riglim = @{setup_riglim($rigid[$e + 3], $limit[$e + 3])}; @riglim = @{setup_riglim($rigid[$e + 3], $limit[$e + 3])};
undef(@tmp); undef(@tmp);
undef(@tmpz); undef(@tmpz);
@ -929,6 +935,188 @@ sub zfs_cgi {
} }
$e++; $e++;
if($title) {
push(@output, " </td>\n");
push(@output, " <td bgcolor='" . $colors->{title_bg_color} . "'>\n");
}
@riglim = @{setup_riglim($rigid[$e + 3], $limit[$e + 3])};
undef(@tmp);
undef(@tmpz);
undef(@CDEF);
push(@tmp, "AREA:oper#00EEEE:Read");
push(@tmp, "GPRINT:oper:LAST: Current\\: %5.1lf%S\\n");
push(@tmp, "AREA:n_opew#4444EE:Write");
push(@tmp, "GPRINT:opew:LAST: Current\\: %5.1lf%S\\n");
push(@tmpz, "AREA:oper#00EEEE:Read");
push(@tmpz, "AREA:n_opew#4444EE:Write");
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}->{medium2});
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;
push(@tmp, "COMMENT: \\n");
push(@tmp, "COMMENT: \\n");
push(@tmp, "COMMENT: \\n");
}
$pic = $rrd{$version}->("$IMG_DIR" . "$IMG[$e]",
"--title=$config->{graphs}->{_zfs6}: $str ($tf->{nwhen}$tf->{twhen})",
"--start=-$tf->{nwhen}$tf->{twhen}",
"--imgformat=$imgfmt_uc",
"--vertical-label=Number",
"--width=$width",
"--height=$height",
@riglim,
$zoom,
@{$cgi->{version12}},
@{$cgi->{version12_small}},
@{$colors->{graph_colors}},
"DEF:oper=$rrd:zfs" . $n . "_oper:AVERAGE",
"DEF:opew=$rrd:zfs" . $n . "_opew:AVERAGE",
"CDEF:n_opew=opew,-1,*",
"CDEF:allvalues=oper,opew,+",
@CDEF,
@tmp);
$err = RRDs::error;
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMG[$e]: $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]",
"--title=$config->{graphs}->{_zfs6}: $str ($tf->{nwhen}$tf->{twhen})",
"--start=-$tf->{nwhen}$tf->{twhen}",
"--imgformat=$imgfmt_uc",
"--vertical-label=Number",
"--width=$width",
"--height=$height",
@riglim,
$zoom,
@{$cgi->{version12}},
@{$cgi->{version12_small}},
@{$colors->{graph_colors}},
"DEF:oper=$rrd:zfs" . $n . "_oper:AVERAGE",
"DEF:opew=$rrd:zfs" . $n . "_opew:AVERAGE",
"CDEF:n_opew=opew,-1,*",
"CDEF:allvalues=oper,opew,+",
@CDEF,
@tmpz);
$err = RRDs::error;
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMGz[$e]: $err\n") if $err;
}
if($title || ($silent =~ /imagetag/ && $graph =~ /zfs4/)) {
if(lc($config->{enable_zoom}) eq "y") {
if(lc($config->{disable_javascript_void}) eq "y") {
push(@output, " <a href=\"" . $config->{url} . "/" . $config->{imgs_dir} . $IMGz[$e] . "\"><img src='" . $config->{url} . "/" . $config->{imgs_dir} . $IMG[$e] . "' border='0'></a>\n");
} else {
if($version eq "new") {
$picz_width = $picz->{image_width} * $config->{global_zoom};
$picz_height = $picz->{image_height} * $config->{global_zoom};
} else {
$picz_width = $width + 115;
$picz_height = $height + 100;
}
push(@output, " <a href=\"javascript:void(window.open('" . $config->{url} . "/" . $config->{imgs_dir} . $IMGz[$e] . "','','width=" . $picz_width . ",height=" . $picz_height . ",scrollbars=0,resizable=0'))\"><img src='" . $config->{url} . "/" . $config->{imgs_dir} . $IMG[$e] . "' border='0'></a>\n");
}
} else {
push(@output, " <img src='" . $config->{url} . "/" . $config->{imgs_dir} . $IMG[$e] . "'>\n");
}
}
$e++;
@riglim = @{setup_riglim($rigid[$e + 3], $limit[$e + 3])};
undef(@tmp);
undef(@tmpz);
undef(@CDEF);
push(@tmp, "AREA:banr_b#00EEEE:Read");
push(@tmp, "GPRINT:banr_b:LAST: Current\\: %4.1lf%S\\n");
push(@tmp, "AREA:n_banw_b#4444EE:Write");
push(@tmp, "GPRINT:banw_b:LAST: Current\\: %4.1lf%S\\n");
push(@tmpz, "AREA:banr_b#00EEEE:Read");
push(@tmpz, "AREA:n_banw_b#4444EE:Write");
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}->{medium2});
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;
push(@tmp, "COMMENT: \\n");
push(@tmp, "COMMENT: \\n");
push(@tmp, "COMMENT: \\n");
}
$pic = $rrd{$version}->("$IMG_DIR" . "$IMG[$e]",
"--title=$config->{graphs}->{_zfs7}: $str ($tf->{nwhen}$tf->{twhen})",
"--start=-$tf->{nwhen}$tf->{twhen}",
"--imgformat=$imgfmt_uc",
"--vertical-label=bytes",
"--width=$width",
"--height=$height",
@riglim,
$zoom,
@{$cgi->{version12}},
@{$cgi->{version12_small}},
@{$colors->{graph_colors}},
"DEF:banr=$rrd:zfs" . $n . "_banr:AVERAGE",
"DEF:banw=$rrd:zfs" . $n . "_banw:AVERAGE",
"CDEF:banr_b=banr,1024,*",
"CDEF:banw_b=banw,1024,*",
"CDEF:n_banw_b=banw_b,-1,*",
"CDEF:allvalues=banr,banw,+",
@CDEF,
@tmp);
$err = RRDs::error;
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMG[$e]: $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]",
"--title=$config->{graphs}->{_zfs7}: $str ($tf->{nwhen}$tf->{twhen})",
"--start=-$tf->{nwhen}$tf->{twhen}",
"--imgformat=$imgfmt_uc",
"--vertical-label=bytes",
"--width=$width",
"--height=$height",
@riglim,
$zoom,
@{$cgi->{version12}},
@{$cgi->{version12_small}},
@{$colors->{graph_colors}},
"DEF:banr=$rrd:zfs" . $n . "_banr:AVERAGE",
"DEF:banw=$rrd:zfs" . $n . "_banw:AVERAGE",
"CDEF:banr_b=banr,1024,*",
"CDEF:banw_b=banw,1024,*",
"CDEF:n_banw_b=banw_b,-1,*",
"CDEF:allvalues=banr,banw,+",
@CDEF,
@tmpz);
$err = RRDs::error;
push(@output, "ERROR: while graphing $IMG_DIR" . "$IMGz[$e]: $err\n") if $err;
}
if($title || ($silent =~ /imagetag/ && $graph =~ /zfs5/)) {
if(lc($config->{enable_zoom}) eq "y") {
if(lc($config->{disable_javascript_void}) eq "y") {
push(@output, " <a href=\"" . $config->{url} . "/" . $config->{imgs_dir} . $IMGz[$e] . "\"><img src='" . $config->{url} . "/" . $config->{imgs_dir} . $IMG[$e] . "' border='0'></a>\n");
} else {
if($version eq "new") {
$picz_width = $picz->{image_width} * $config->{global_zoom};
$picz_height = $picz->{image_height} * $config->{global_zoom};
} else {
$picz_width = $width + 115;
$picz_height = $height + 100;
}
push(@output, " <a href=\"javascript:void(window.open('" . $config->{url} . "/" . $config->{imgs_dir} . $IMGz[$e] . "','','width=" . $picz_width . ",height=" . $picz_height . ",scrollbars=0,resizable=0'))\"><img src='" . $config->{url} . "/" . $config->{imgs_dir} . $IMG[$e] . "' border='0'></a>\n");
}
} else {
push(@output, " <img src='" . $config->{url} . "/" . $config->{imgs_dir} . $IMG[$e] . "'>\n");
}
}
$e++;
if($title) { if($title) {
push(@output, " </td>\n"); push(@output, " </td>\n");
push(@output, " </tr>\n"); push(@output, " </tr>\n");

View File

@ -332,8 +332,8 @@ secure_log_date_format = %b %e
<zfs> <zfs>
max_pools = 5 max_pools = 5
list = pool1, pool2 list = pool1, pool2
rigid = 0, 0, 0, 0, 2, 0, 2 rigid = 0, 0, 0, 0, 2, 0, 0
limit = 1000, 1000, 1000, 1000, 100, 1000, 100 limit = 1000, 1000, 1000, 1000, 100, 1000, 1000
</zfs> </zfs>
@ -978,6 +978,8 @@ graph_name = system, kern, proc, hptemp, lmsens, gensens, ipmi, ambsens, nvidia,
_zfs3 = L2ARC cache _zfs3 = L2ARC cache
_zfs4 = Pool data usage _zfs4 = Pool data usage
_zfs5 = Pool usage _zfs5 = Pool usage
_zfs6 = Operations
_zfs7 = Bandwidth
_du = Directory usage _du = Directory usage
_net1 = Network traffic _net1 = Network traffic
_net2 = Network packets _net2 = Network packets