mirror of
https://github.com/munin-monitoring/contrib.git
synced 2025-07-21 18:41:03 +00:00
Add plugin for Voldemort NoSQL data store to pull throughput and call stats
This commit is contained in:
parent
1253b1ded8
commit
e342c815dc
1 changed files with 64 additions and 0 deletions
64
plugins/voldemort/voldemort
Normal file
64
plugins/voldemort/voldemort
Normal file
|
@ -0,0 +1,64 @@
|
|||
#!/usr/bin/env jruby
|
||||
|
||||
# Description: Voldemort plugin to pull basic stats on throughput and number of calls into Munin
|
||||
# Author: Peter Crossley - Webtrends Inc
|
||||
|
||||
require 'rubygems'
|
||||
require 'jmx4r'
|
||||
|
||||
|
||||
#%# family=auto
|
||||
#%# capabilities=autoconf
|
||||
|
||||
# friendly name => result of listPerfStatsKeys via JMX
|
||||
keys = {
|
||||
"Throughput" => { "vlabel" => "rate",
|
||||
"type" => "ABSOLUTE",
|
||||
"values" => ["all_operation_throughput","delete_throughput", "get_all_throughput", "get_throughput", "put_throughput"]
|
||||
},
|
||||
"Number of Calls" => { "vlabel" => "counts",
|
||||
"type" => "COUNTER",
|
||||
"values" => ["number_of_calls_to_delete","number_of_calls_to_get", "number_of_calls_to_get_all",
|
||||
"number_of_calls_to_put", "number_of_exceptions"]
|
||||
}
|
||||
}
|
||||
|
||||
if ARGV[0] == "config"
|
||||
keys.each_key do |key|
|
||||
puts "multigraph voldemort_#{key.gsub(" ", "_")}"
|
||||
puts "graph_title #{key}"
|
||||
puts "graph_scale no"
|
||||
puts "graph_category voldemort"
|
||||
puts "graph_vlabel #{keys[key]['vlabel']}"
|
||||
for data in keys[key]['values'] do
|
||||
puts "#{data}.type #{keys[key]['type']}"
|
||||
puts "#{data}.label #{data.gsub("_", " ")}"
|
||||
end
|
||||
puts
|
||||
end
|
||||
exit 0
|
||||
elsif ARGV[0] == "autoconf"
|
||||
puts "yes"
|
||||
exit 0
|
||||
else
|
||||
|
||||
# Add JMX port
|
||||
# JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=5400 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false"
|
||||
# Tell JBossAS to use the platform MBean server
|
||||
# JAVA_OPTS="$JAVA_OPTS -Djboss.platform.mbeanserver"
|
||||
# Make the platform MBean server able to work with JBossAS MBeans
|
||||
# JAVA_OPTS="$JAVA_OPTS -Djavax.management.builder.initial=org.jboss.system.server.jmx.MBeanServerBuilderImpl"
|
||||
# JBOSS_CLASSPATH="/opt/webtrends/jboss/bin/mbean"
|
||||
JMX::MBean.establish_connection :port => 5400
|
||||
vs = JMX::MBean.find_by_name "voldemort.store.stats.aggregate:type=aggregate-perf"
|
||||
|
||||
keys.each_key do |key|
|
||||
puts "multigraph voldemort_#{key.gsub(" ", "_")}"
|
||||
for data in keys[key]['values'] do
|
||||
puts "#{data}.value #{begin vs.send("#{data}") rescue 0 end}"
|
||||
end
|
||||
puts
|
||||
end
|
||||
end
|
||||
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue