munin-contrib/plugins/condor/condor_ops_

111 lines
3.5 KiB
Bash
Executable File

#!/bin/bash
#
# Wildard-plugin to monitor integer and floating point
# performance capabilities of a Condor pool.
#
# Author: Šarūnas Burdulis, sarunas(a)mail.saabnet.com, 2008
#
# Runs 'condor_status -server',
# gets totals for MIPS and KFLOPS.
#
# Parameters understood:
#
# config (required)
# autoconf (optional - used by munin-config)
# suggest (optional - used by munin-config)
#
# Configurable variables:
#
# env.condor_status - Path to condor_status executable,
# defaults to /usr/local/condor/bin/condor_status
# env.constraint - Condor ClassAds constraint(s), as they are
# specified on the condor_status command line. For example,
# to monitor 64-bit Linux nodes only, set:
# env.constraint 'arch=="x86_64" && opsys=="linux"'
#
# Magic markers - optional - used by installation scripts and
# munin-config:
#
#%# family=contrib
#%# capabilities=autoconf
# optional tag
TAG=`basename $0 | sed 's/^condor_ops_//g'`
if [ -z "$TAG" ]; then
GRAPHTITLE="MIPS, MFLOPS"
else
GRAPHTITLE="MIPS, MFLOPS (${TAG})"
fi
# env.condor_status
if [ ! -z "$condor_status" ]; then
CS="$condor_status"
else
CS="/usr/local/condor/bin/condor_status"
fi
# env.constraint
if [ ! -z "$constraint" ]; then
CONS="-constraint ${constraint}"
else
CONS=
fi
if [ "$1" = "autoconf" ]; then
echo "no"
exit 0
fi
if [ "$1" = "suggest" ]; then
echo "For example: condor_ops_Linux-x86_64."
exit 0
fi
if [ "$1" = "config" ]; then
echo "graph_title "$GRAPHTITLE""
echo "graph_order mips_cur mips_max mflops_cur mflops_max"
echo "graph_args --lower-limit 0 "
echo 'graph_vlabel MIPS, MFLOPS'
echo 'graph_scale no'
echo 'graph_info Shows MIPS and MFLOPS from condor_status.'
echo 'graph_category htc'
echo 'graph_period second'
echo 'mips_cur.label MIPS claimed'
echo 'mips_cur.draw LINE2'
echo 'mips_cur.min 0'
echo 'mips_cur.max 200000'
echo 'mips_cur.type GAUGE'
echo "mips_cur.info Total (millions of integer operations)/s in Claimed nodes"
echo 'mips_max.label MIPS max. possible'
echo 'mips_max.draw LINE'
echo 'mips_max.min 0'
echo 'mips_max.max 200000'
echo 'mips_max.type GAUGE'
echo "mips_max.info Total capability in (millions of integer operations)/s"
echo 'mflops_cur.label MFLOPS claimed'
echo 'mflops_cur.draw LINE2'
echo 'mflops_cur.min 0'
echo 'mflops_cur.max 200000'
echo 'mflops_cur.type GAUGE'
echo "mflops_cur.info Total (millions of floating point operations)/s in Claimed nodes"
echo 'mflops_max.label MFLOPS max. possible'
echo 'mflops_max.draw LINE'
echo 'mflops_max.min 0'
echo 'mflops_max.max 200000'
echo 'mflops_max.type GAUGE'
echo "mflops_max.info Total capability in (millions of floating point operations)/s"
exit 0
fi
# max possible:
#condor_status -cons 'arch=="x86_64" && opsys=="linux"' -totals -server
# Machines Avail Memory Disk MIPS KFLOPS
# Total 30 30 48960 257925730 104576 31092042
eval $CS $CONS -totals -server | awk 'BEGIN { mipsc=0; mflopsc=0 } /Total/ {mips = $6; kflops = $7; mflops = int(kflops/1000) } END {print "mips_max.value " mips "\nmflops_max.value " mflops}'
# currently using:
#condor_status -cons 'arch=="x86_64" && opsys=="linux"' -totals -server -claimed
# Machines MIPS KFLOPS AvgLoadAvg
# Total 28 104576 29093286 0.960
eval $CS $CONS -totals -server -claimed | awk 'BEGIN { mipsc=0; mflopsc=0 } /Total/ { mipsc = $3; kflopsc = $4; mflopsc = int(kflopsc/1000) } END {print "mips_cur.value " mipsc "\nmflops_cur.value " mflopsc}'