mirror of
https://github.com/munin-monitoring/contrib.git
synced 2025-07-22 22:25:23 +00:00
Using a timed grep with a state computation is usually mostly wrong. The DERIVE field type is specifically designed for that very purpose. Closes #264
126 lines
2.7 KiB
Bash
Executable file
126 lines
2.7 KiB
Bash
Executable file
#! /bin/bash
|
|
#
|
|
# Munin Plugin
|
|
# to count logins to your dovecot mailserver
|
|
#
|
|
# Created by Dominik Schulz <lkml@ds.gauner.org>
|
|
# http://developer.gauner.org/munin/
|
|
# Contributions by:
|
|
# - Stephane Enten <tuf@delyth.net>
|
|
# - Steve Schnepp <steve.schnepp@pwkf.org>
|
|
#
|
|
# Parameters understood:
|
|
#
|
|
# config (required)
|
|
# autoconf (optional - used by munin-config)
|
|
#
|
|
# Config variables:
|
|
#
|
|
# logfile - Where to find the syslog file
|
|
#
|
|
# Add the following line to a file in /etc/munin/plugin-conf.d:
|
|
# env.logfile /var/log/your/logfile.log
|
|
#
|
|
# Magic markers (optional - used by munin-config and installation scripts):
|
|
#
|
|
#%# family=auto
|
|
#%# capabilities=autoconf
|
|
|
|
######################
|
|
# Configuration
|
|
######################
|
|
EXPR_BIN=/usr/bin/expr
|
|
LOGFILE=${logfile:-/var/log/mail.log}
|
|
######################
|
|
|
|
if [ "$1" = "autoconf" ]; then
|
|
echo yes
|
|
exit 0
|
|
fi
|
|
|
|
if [ "$1" = "config" ]; then
|
|
echo 'graph_title Dovecot Logins'
|
|
echo 'graph_category Mail'
|
|
echo 'graph_args --base 1000 -l 0'
|
|
echo 'graph_vlabel Login Counters'
|
|
|
|
for t in Total TLS SSL IMAP POP3
|
|
do
|
|
field=$(echo $t | tr '[:upper:]' '[:lower:]')
|
|
echo "login_$field.label $t Logins"
|
|
echo "login_$field.type DERIVE"
|
|
echo "login_$field.min 0"
|
|
done
|
|
|
|
echo 'connected.label Connected Users'
|
|
|
|
exit 0
|
|
fi
|
|
|
|
######################
|
|
# Total Logins
|
|
######################
|
|
echo -en "login_total.value "
|
|
VALUE=$(egrep '[dovecot]?.*Login' $LOGFILE | sort | wc -l)
|
|
if [ ! -z "$VALUE" ]; then
|
|
echo "$VALUE"
|
|
else
|
|
echo "0"
|
|
fi
|
|
echo -n
|
|
######################
|
|
# Connected Users
|
|
######################
|
|
DISCONNECTS=$(egrep '[dovecot]?.*Disconnected' $LOGFILE | sort | wc -l)
|
|
CONNECTS=$(egrep '[dovecot]?.*Login' $LOGFILE | sort | wc -l)
|
|
VALUE=$($EXPR_BIN $CONNECTS - $DISCONNECTS)
|
|
if [ -z "$DISCON" ] || [ "$DISCON" -lt 0 ]; then
|
|
DISCON=0
|
|
fi
|
|
echo -en "connected.value "
|
|
echo $DISCON
|
|
echo -n
|
|
######################
|
|
# TLS Logins
|
|
######################
|
|
echo -en "login_tls.value "
|
|
VALUE=$(egrep '[dovecot]?.*Login.*TLS' $LOGFILE | sort | wc -l)
|
|
if [ ! -z "$VALUE" ]; then
|
|
echo "$VALUE"
|
|
else
|
|
echo "0"
|
|
fi
|
|
echo -n
|
|
######################
|
|
# SSL Logins
|
|
######################
|
|
echo -en "login_ssl.value "
|
|
VALUE=$(egrep '[dovecot]?.*Login.*SSL' $LOGFILE | sort | wc -l)
|
|
if [ ! -z "$VALUE" ]; then
|
|
echo "$VALUE"
|
|
else
|
|
echo "0"
|
|
fi
|
|
echo -n
|
|
######################
|
|
# IMAP Logins
|
|
######################
|
|
echo -en "login_imap.value "
|
|
VALUE=$(egrep '[dovecot]?.*imap.*Login' $LOGFILE | sort | wc -l)
|
|
if [ ! -z "$VALUE" ]; then
|
|
echo "$VALUE"
|
|
else
|
|
echo "0"
|
|
fi
|
|
echo -n
|
|
######################
|
|
# POP3 Logins
|
|
######################
|
|
echo -en "login_pop3.value "
|
|
VALUE=$(egrep '[dovecot]?.*pop3.*Login' $LOGFILE | sort | wc -l)
|
|
if [ ! -z "$VALUE" ]; then
|
|
echo "$VALUE"
|
|
else
|
|
echo "0"
|
|
fi
|
|
echo -n
|