- Repository
- Munin (contrib)
- Last change
- 2020-10-24
- Graph Categories
- Family
- snmpauto
- Capabilities
- Keywords
- Language
- Perl
- License
- GPL-2.0-only
- Authors
snmp__gsa_docs
Name
snmp__gsa_docs - SNMP wildcard plugin to monitor Google Search Appliance (GSA) document statistics
Applicable Systems
A GSA running software version 5.0 or above. See [1] for counters exported via SNMP. Usage of SNMPv3 is recommended, with AuthPriv, and the SHA authentication scheme.
[1]: https://developers.google.com/search-appliance/documentation/50/help_gsa/admin_snmp
Configuration
Create a “Munin” user on the GSA SNMP configuration, and then use something similar to the following:
[snmpv3_gsa.host.name_*]
env.v3username munin
env.v3authprotocol sha
env.v3authpassword your-auth-passwd
env.v3privprotocol des
env.v3privpassword your-priv-passwd
Please see ‘perldoc Munin::Plugin::SNMP’ for further configuration information.
Interpretation
The graph shows statistics about the documents index and queries per minute.
Mib Information
This plugin requires the GOOGLE-MIB and GSA-MIB and will report
GSA-MIB::docsServed.0 = INTEGER: .. GSA-MIB::docErrors.0 = INTEGER: … GSA-MIB::docsFound.0 = INTEGER: … GSA-MIB::docBytes.0 = INTEGER: …. GSA-MIB::qpm.0 = INTEGER: ………
Magic Markers
#%# family=snmpauto
#%# capabilities=snmpconf
Version
$Id$
Bugs
None known.
Author
Copyright (C) 2013 Marcello Barnaba vjt@openssl.it based on snmp__if_, Copyright (C) 2004-2009 Jimmy Olsen, Daginn Ilmari Mannsåker.
License
GPLv2
#!/usr/bin/perl -w
# -*- cperl -*-
=head1 NAME
snmp__gsa_docs - SNMP wildcard plugin to monitor Google Search Appliance (GSA) document statistics
=head1 APPLICABLE SYSTEMS
A GSA running software version 5.0 or above. See [1] for counters
exported via SNMP. Usage of SNMPv3 is recommended, with AuthPriv,
and the SHA authentication scheme.
[1]: https://developers.google.com/search-appliance/documentation/50/help_gsa/admin_snmp
=head1 CONFIGURATION
Create a "Munin" user on the GSA SNMP configuration, and then use
something similar to the following:
[snmpv3_gsa.host.name_*]
env.v3username munin
env.v3authprotocol sha
env.v3authpassword your-auth-passwd
env.v3privprotocol des
env.v3privpassword your-priv-passwd
Please see 'perldoc Munin::Plugin::SNMP' for further configuration
information.
=head1 INTERPRETATION
The graph shows statistics about the documents index and queries per minute.
=head1 MIB INFORMATION
This plugin requires the GOOGLE-MIB and GSA-MIB and will report
GSA-MIB::docsServed.0 = INTEGER: ..
GSA-MIB::docErrors.0 = INTEGER: ...
GSA-MIB::docsFound.0 = INTEGER: ...
GSA-MIB::docBytes.0 = INTEGER: ....
GSA-MIB::qpm.0 = INTEGER: .........
=head1 MAGIC MARKERS
#%# family=snmpauto
#%# capabilities=snmpconf
=head1 VERSION
$Id$
=head1 BUGS
None known.
=head1 AUTHOR
Copyright (C) 2013 Marcello Barnaba <vjt@openssl.it> based on snmp__if_,
Copyright (C) 2004-2009 Jimmy Olsen, Daginn Ilmari Mannsåker.
=head1 LICENSE
GPLv2
=cut
use strict;
use Munin::Plugin;
use Munin::Plugin::SNMP;
need_multigraph();
# This is the snmpwalk:
# .1.3.6.1.4.1.11129.1.1.1.0 = INTEGER: Running(1) ## GSA-MIB::crawlRunning.0 = INTEGER: Running(1)
# .1.3.6.1.4.1.11129.1.1.2.1.0 = INTEGER: 855802 ## GSA-MIB::docsServed.0 = INTEGER: 855802
# .1.3.6.1.4.1.11129.1.1.2.2.0 = INTEGER: 0 ## GSA-MIB::crawlingRate.0 = INTEGER: 0
# .1.3.6.1.4.1.11129.1.1.2.3.0 = INTEGER: 501606 ## GSA-MIB::docBytes.0 = INTEGER: 501606
# .1.3.6.1.4.1.11129.1.1.2.4.0 = INTEGER: 1 ## GSA-MIB::todayDocsCrawled.0 = INTEGER: 1
# .1.3.6.1.4.1.11129.1.1.2.5.0 = INTEGER: 0 ## GSA-MIB::docErrors.0 = INTEGER: 0
# .1.3.6.1.4.1.11129.1.1.2.6.0 = INTEGER: 860683 ## GSA-MIB::docsFound.0 = INTEGER: 860683
# .1.3.6.1.4.1.11129.1.1.2.7.0 = INTEGER: Off(0) ## GSA-MIB::batchCrawlRunning.0 = INTEGER: Off(0)
# .1.3.6.1.4.1.11129.1.1.2.8.0 = INTEGER: 0 ## GSA-MIB::batchCrawlStartTime.0 = INTEGER: 0
# .1.3.6.1.4.1.11129.1.1.2.9.0 = INTEGER: 0 ## GSA-MIB::batchCrawlEndTime.0 = INTEGER: 0
# .1.3.6.1.4.1.11129.1.2.1.0 = INTEGER: 0 ## GSA-MIB::qpm.0 = INTEGER: 0
# .1.3.6.1.4.1.11129.1.3.1.1.0 = INTEGER: green(0) ## GSA-MIB::diskHealth.0 = INTEGER: green(0)
# .1.3.6.1.4.1.11129.1.3.1.2.0 = STRING: ## GSA-MIB::diskErrors.0 = STRING:
# .1.3.6.1.4.1.11129.1.3.2.1.0 = INTEGER: green(0) ## GSA-MIB::temperatureHealth.0 = INTEGER: green(0)
# .1.3.6.1.4.1.11129.1.3.2.2.0 = STRING: ## GSA-MIB::temperatureErrors.0 = STRING:
# .1.3.6.1.4.1.11129.1.3.3.1.0 = INTEGER: green(0) ## GSA-MIB::machineHealth.0 = INTEGER: green(0)
# .1.3.6.1.4.1.11129.1.3.3.2.0 = STRING: ## GSA-MIB::machineErrors.0 = STRING:
my $entryDocsServed = "1.3.6.1.4.1.11129.1.1.2.1.0";
my $entryDocBytes = "1.3.6.1.4.1.11129.1.1.2.3.0";
my $entryDocErrors = "1.3.6.1.4.1.11129.1.1.2.5.0";
my $entryDocsFound = "1.3.6.1.4.1.11129.1.1.2.6.0";
my $entryQPM = "1.3.6.1.4.1.11129.1.2.1.0" ; # Queries per Minute
if (defined $ARGV[0] and $ARGV[0] eq "snmpconf") {
print "require $entryDocsServed\n";
print "require $entryDocErrors\n";
print "require $entryDocsFound\n";
print "require $entryDocBytes\n";
print "require $entryQPM\n";
exit 0;
}
# SNMP needed for both config and fetch.
my $session = Munin::Plugin::SNMP->session();
my $response;
if ($ARGV[0] and $ARGV[0] eq "config") {
my ($host,undef,$version) = Munin::Plugin::SNMP->config_session();
print "host_name $host\n" unless $host eq 'localhost';
print "multigraph gsa_documents\n";
print "graph_title GSA documents statistics\n";
print "graph_order found served errors\n";
print "graph_args --base 1000\n";
print "graph_vlabel Documents\n";
print "graph_category search\n";
print "graph_info This graph shows document statistics for the GSA\n";
print "served.label served\n";
print "served.type GAUGE\n";
print "served.graph yes\n";
print "errors.label errors\n";
print "errors.type GAUGE\n";
print "errors.graph yes\n";
print "found.label found\n";
print "found.type GAUGE\n";
print "found.graph yes\n";
print "multigraph gsa_storage\n";
print "graph_title GSA storage statistics\n";
print "graph_order bytes\n";
print "graph_vlabel Megabytes Filtered\n";
print "graph_category search\n";
print "graph_info This graph shows the GSA index size\n";
print "bytes.label bytes\n";
print "bytes.type GAUGE\n";
print "bytes.graph yes\n";
print "multigraph gsa_qpm\n";
print "graph_title GSA Queries Per Minute\n";
print "graph_order qpm\n";
print "graph_vlabel Queries per minute\n";
print "graph_category search\n";
print "graph_info This graph shows how many Queries Per Minute the GSA receives\n";
print "qpm.label count\n";
print "qpm.type DERIVE\n";
print "qpm.graph yes\n";
exit 0;
}
print "multigraph gsa_documents\n";
if (defined ($response = $session->get_single($entryDocsServed))) {
print "served.value ", $response, "\n";
}
if (defined ($response = $session->get_single($entryDocErrors))) {
print "errors.value ", $response, "\n";
}
if (defined ($response = $session->get_single($entryDocsFound))) {
print "found.value ", $response, "\n";
}
print "multigraph gsa_storage\n";
if (defined ($response = $session->get_single($entryDocBytes))) {
print "bytes.value ", $response, "\n";
}
print "multigraph gsa_qpm\n";
if (defined ($response = $session->get_single($entryQPM))) {
print "qpm.value ", $response, "\n";
}