Repository
Munin (contrib)
Last change
2018-09-16
Graph Categories
Family
contrib
Capabilities
Keywords
Language
Bash
Authors

if_uptime

Sadly there is no documentation for this plugin.

#!/bin/bash
# This script is intended for use with Munin to monitor
# network interface uptime. Usually this would be ppp0 or smth.
# Tested under Ubuntu Gutsy.
# v. 1.00, 12/15/2007
# (c) Alex Yanchenko (yanchenko{at}gmail.com), 2007
# Distributed under GPL v.3 (http://www.gnu.org/licenses/gpl-3.0.txt)
#
# The plugin can utilize automatic configuration,
# here are the basic steps (require root privileges):
# 1. Copy it as /usr/share/munin/plugins/if_uptime
# 2. Customize interfaces to monitor
# 3. Make executable: "chmod 755 /usr/share/munin/plugins/if_uptime"
# 4. Run "munin-node-configure --shell", you should see smth like
# "ln -s /usr/share/munin/plugins/if_uptime /etc/munin/plugins/if_uptime"
# Multiple interface monitoring is supported as well. Customize below.
# 5. Run the proposed command to create a link.
# 6. To verify, run "munin-node-configure", you should notice the "if_uptime" record
#
# Plugin                     | Used | Suggestions
# ------                     | ---- | -----------
# if_uptime                  | yes  |
#
# 7. Restart munin: "/etc/init.d/munin-node restart"
# 8. Hold on for 5 minutes at most and watch the graph appear.
#
#%# family=contrib
#%# capabilities=autoconf

#----- PROPERTIES START -----#
# An array of external interfaces to monitor, space-separated.
# In case vnstat is installed, interface names will be fetced
# from it, 'nicknames'included.
INTERFACES=(ppp0)

# Uptime metrics.
# Literals of seconds, minutes, hours and days are accepted.
METRICS=minutes
#----- PROPERTIES END -----#

# Function to get interface name from vnstat if it's available.
# Accepts interface name as the only argument.
function IF_NAME() {
	ARG=$1
	if [[ $(which vnstat &>/dev/null; echo $?) == 0 ]]
		then
			IF_NAME="$(vnstat | grep "$ARG" | cut -d" " -f2,3 | cut -d":" -f1)"
		else
			IF_NAME="$ARG"
	fi
	echo $IF_NAME
}

# Converts seconds (uptime value) into desired metrics value.
# Accepts uptime value as the only argument. Relies on the
# METRICS variable set above.
function SECONDS_CONVERTER() {
	ARG=$1
		case $METRICS in
	seconds)
		echo "$ARG"
		;;
	minutes)
		echo $((ARG / 60))
		;;
	days)
		echo $((ARG / 86400))
		;;
	hours)
		echo $((ARG / 3600))
		;;
	*)
		echo "value value"
		exit 1
		;;
	esac
}

# Helper function that collects and stores data.
# Accepts interface name as the only argument.
function FETCH_DATA() {

IF="$1"
# File to store data between rounds. Per-line values:
# bytes received
# timestamp
# total uptime
FILE=/tmp/if_uptime_"$IF"

if [[ !(-e "$FILE") ]]
	then
		cat > $FILE << EOF
0
$(date +%s)
0
EOF
fi
# Read previous values
		previous_received=$(head -n 1 < $FILE)
		previous_timestamp=$(head -n 2 < $FILE | tail -n 1)
		previous_uptime=$(tail -n 1 < $FILE)
# Get current values
		current_received=$(grep "$IF" < /proc/net/dev | sed 's|: *|:|g' | cut -d":" -f2 | cut -d" " -f1)
		current_timestamp=$(date +%s)
# Evaluate whether interface went down
		if [[ $current_received -gt $previous_received ]]
			then
				current_uptime=$(( $previous_uptime+($current_timestamp-$previous_timestamp) ))
			else
				current_uptime="0"
		fi
# Write new values
		cat > $FILE << EOF
$current_received
$current_timestamp
$current_uptime
EOF

}
# Munin routines
	case "$1" in
		autoconf)
			if [[ $(ifconfig &> /dev/null; echo "$?") == 0 ]]; then
				echo yes
			else
				echo "no (ifconfig doesn't work out)"
			fi
			exit 0
		;;
		config)
cat << EOM
graph_title Interface Uptime Meter
graph_category network
graph_info Get to know how often your ISP violates SLA.
graph_vlabel Interface uptime, $METRICS
graph_args --base 1000 --lower-limit 0
EOM
			for (( i=0; i<"${#INTERFACES[*]}"; i++ ))
				do
cat << EOM
${INTERFACES[$i]}.draw LINE3
${INTERFACES[$i]}.label $(IF_NAME ${INTERFACES[$i]})
EOM
				done
			exit 0
		;;
			*)
# Print data for Munin
			for (( i=0; i<"${#INTERFACES[*]}"; i++ ))
				do
					FETCH_DATA ${INTERFACES[$i]}
					echo "${INTERFACES[$i]}.value $(SECONDS_CONVERTER $current_uptime)"
				done
			exit 0
		;;
		esac