1
0
Fork 0
mirror of https://github.com/munin-monitoring/contrib.git synced 2025-07-24 18:07:20 +00:00

- have some dirs

This commit is contained in:
Steve Schnepp 2012-02-13 18:24:46 +01:00
parent 0b089ea777
commit 08346aac58
687 changed files with 0 additions and 0 deletions

127
plugins/squid/squid_efficiency Executable file
View file

@ -0,0 +1,127 @@
#!/bin/bash
#
# Copyright (C) 2006-2009 Benjamin Schweizer. All rights reserved.
#
# Permission to use, copy, modify, and/or distribute this software for any
# purpose with or without fee is hereby granted, provided that the above
# copyright notice and this permission notice appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#
#
# Abstract
# ~~~~~~~~
# This is a plugin for the munin monitoring system. It graphs the cache
# efficiency of your squid proxy servers and shows nice graphs for average
# byte and request hits.
#
# Authors
# ~~~~~~~
# Benjamin Schweizer, http://benjamin-schweizer.de/contact
#
# Changes
# ~~~~~~~
# 2010-10-11: paulm: uses squidclient instead of netcat; some beautification.
# 2010-01-20, homyakov: added disk and memory stats
# 2009-11-25, volker: added config options and docs
# 2009-11-19, benjamin: fixed squid3 compatibility, minor rewrite
# 2006-11-16, benjamin: removed 5 minutes stats, fixed 5% bug
# 2006-10-26, benjamin: excluded negative values from result
# 2006-10-11, benjamin: initial release.
#
# Todo
# ~~~~
# - we'll see
#
# Munin:
#%# family=auto
#%# capabilities=autoconf
#
# Config
# ~~~~~~
# This plugin supports munin-autoconf, but you might need to change the host
# and port according to your actual setup. You can overwrite the defaults
# in your node config (/etc/munin/plugin-conf.d/) like this:
#
# [squid_efficiency]
# env.squidhost yourhost.example.com
# env.squidport 8080
#
host=${squidhost:-localhost}
port=${squidport:-3128}
test "$1" = "config" && {
echo 'graph_title Squid Efficiency'
echo 'graph_info This graph shows the proxy efficiency over the last five mins.'
echo 'graph_category squid'
echo "graph_args --lower-limit 0 --upper-limit 100"
echo 'graph_vlabel %'
echo 'request.label request hits'
echo 'byte.label byte hits'
echo 'memory.label memory request hits'
echo 'disk.label disk request hits'
exit 0
}
# squid2
# Request Hit Ratios: 5min: 0.0%, 60min: 17.4%
# Byte Hit Ratios: 5min: 75.0%, 60min: 12.0%
# squid3
# Hits as % of all requests: 5min: 0.0%, 60min: 0.0%
# Hits as % of bytes sent: 5min: 100.0%, 60min: 100.0%
DUMP=`squidclient -p $port -l $host cache_object://$host/info`
# Request efficiency
SQUID_LINE=`echo "$DUMP" | grep -E "Request Hit Ratios|Hits as % of all requests"`
if [ $? -eq 0 ] ; then
# for the last hour:
#REQUEST_HITS=`echo $SQUID_LINE | cut -d ":" -f4 | cut -d "." -f1`
# for the last five mins:
REQUEST_HITS=`echo $SQUID_LINE | cut -d ":" -f3 | cut -d "." -f1`
test "$REQUEST_HITS" -gt 0 || REQUEST_HITS=0
echo "request.value ${REQUEST_HITS}"
fi
# Byte efficiency
SQUID_LINE=`echo "$DUMP" | grep -E "Byte Hit Ratios|Hits as % of bytes sent"`
if [ $? -eq 0 ] ; then
# for the last hour:
#BYTE_HITS=`echo $SQUID_LINE | cut -d ":" -f4 | cut -d "." -f1`
# for the last five mins:
BYTE_HITS=`echo $SQUID_LINE | cut -d ":" -f3 | cut -d "." -f1`
test "$BYTE_HITS" -gt 0 || BYTE_HITS=0
echo "byte.value ${BYTE_HITS}"
fi
# Memory
SQUID_LINE=`echo "$DUMP" | grep -E "Request Memory Hit Ratios|Memory hits as % of hit requests"`
if [ $? -eq 0 ] ; then
# for the last hour:
#MEM_REQUEST_HITS=`echo "$SQUID_LINE" | cut -d ":" -f4 | cut -d "." -f1 | xargs echo`
# for the last five mins:
MEM_REQUEST_HITS=`echo "$SQUID_LINE" | cut -d ":" -f3 | cut -d "." -f1 | xargs echo`
test $MEM_REQUEST_HITS -gt 0 || MEM_REQUEST_HITS=0
echo "memory.value ${MEM_REQUEST_HITS}"
fi
# Disk
SQUID_LINE=`echo "$DUMP" | grep -E "Request Disk Hit Ratios|Disk hits as % of hit requests"`
if [ $? -eq 0 ] ; then
# for the last hour:
#DISK_REQUEST_HITS=`echo "$SQUID_LINE" | cut -d ":" -f4 | cut -d "." -f1 | xargs echo`
# for the last five mins:
DISK_REQUEST_HITS=`echo "$SQUID_LINE" | cut -d ":" -f3 | cut -d "." -f1 | xargs echo`
test $DISK_REQUEST_HITS -gt 0 || DISK_REQUEST_HITS=0
echo "disk.value ${DISK_REQUEST_HITS}"
fi
# eof.

61
plugins/squid/squid_times Executable file
View file

@ -0,0 +1,61 @@
#!/bin/sh
#
# Copyright (C) 2008 Olivier DELHOMME. All rights reserved.
# License GPL V2 or higher
#
# Abstract
# munin plugin that logs the cache mean services times
# Requires netcat (here nc)
#
# Authors
# . Olivier Delhomme <olivierdelhomme at gmail dot com>
#
#%# family=auto
#%# capabilities=autoconf
if [ "$1" = "autoconf" ]; then
SQUID_STATS=`printf "GET cache_object://localhost/info HTTP/1.0\n\n" | netcat localhost 3128`
if [ -n "${SQUID_STATS}" ]; then
echo yes
exit 0
else
echo "no (HTTP GET failed)"
exit 1
fi
fi
if [ "$1" = "config" ]; then
echo 'graph_title Squid Median Services Times'
echo 'graph_info This graph shows the proxy median services response times.'
echo 'graph_category squid'
echo 'graph_args --lower-limit 0'
echo 'graph_vlabel median reponse times (s)'
echo 'mean_http.label Http'
echo 'mean_cmis.label Cache misses'
echo 'mean_chits.label Cache hits'
echo 'mean_nhits.label Near hits'
echo 'mean_nmr.label Not-modified replies'
echo 'mean_dnsl.label Dns lookups'
echo 'mean_icpq.label Icp queries'
exit 0
fi
SQUID_TIME=$(printf "GET cache_object://localhost/info HTTP/1.0\n\n" | nc localhost 3128)
SQUID_TIME_HTTP=$(echo "$SQUID_TIME" | grep "HTTP Requests (All)" | cut -d':' -f2 | sed -e "s/^\ *//" | cut -d' ' -f1)
SQUID_TIME_CACHE_MISSES=$(echo "$SQUID_TIME" | grep "Cache Misses" | cut -d':' -f2 | sed -e "s/^\ *//" | cut -d' ' -f1)
SQUID_TIME_CACHE_HITS=$(echo "$SQUID_TIME" | grep "Cache Hits" | cut -d':' -f2 | sed -e "s/^\ *//" | cut -d' ' -f1)
SQUID_TIME_NEAR_HITS=$(echo "$SQUID_TIME" | grep "Near Hits" | cut -d':' -f2 | sed -e "s/^\ *//" | cut -d' ' -f1)
SQUID_TIME_NM_REPLIES=$(echo "$SQUID_TIME" | grep "Not-Modified Replies" | cut -d':' -f2 | sed -e "s/^\ *//" | cut -d' ' -f1)
SQUID_TIME_DNS_LOOKUPS=$(echo "$SQUID_TIME" | grep "DNS Lookups" | cut -d':' -f2 | sed -e "s/^\ *//" | cut -d' ' -f1)
SQUID_TIME_ICP_QUERIES=$(echo "$SQUID_TIME" | grep "ICP Queries" | cut -d':' -f2 | sed -e "s/^\ *//" | cut -d' ' -f1)
echo "mean_http.value $SQUID_TIME_HTTP"
echo "mean_cmis.value $SQUID_TIME_CACHE_MISSES"
echo "mean_chits.value $SQUID_TIME_CACHE_HITS"
echo "mean_nhits.value $SQUID_TIME_NEAR_HITS"
echo "mean_nmr.value $SQUID_TIME_NM_REPLIES"
echo "mean_dnsl.value $SQUID_TIME_DNS_LOOKUPS"
echo "mean_icpq.value $SQUID_TIME_ICP_QUERIES"