Repository
Munin (contrib)
Last change
2020-08-08
Graph Categories
Family
auto
Capabilities
Keywords
Language
Bash
License
GPL-2.0-only
Authors

dm_cache_statistics_

Name

dm_cache_statistics_ - Wildcard-plugin to dm-cache statistics.

Configuration

This plugin does not normally require configuration.

The plugin may need to run as root to determine dm-cache status. This is configured like this:

[dm_cache_*]
        user root

This is a wildcard plugin. To monitor a cached device-mapper volume, link volume to this file. For example,

ln -s /usr/share/munin/plugins/dm_cache_statistics_ \
      /etc/munin/plugins/dm_cache_statistics_vg_1122____lv_home

will monitor vg_1122-lv_home.

Please note that ____ (4 underscores) is replaced by - (dash) symbol. This is workaround for http://munin-monitoring.org/ticket/1236

Cached volumes found in dmsetup status can be monitored.

Author

Original idea: Steinar H. Gunderson sgunderson@bigfoot.com Found in Google by keywords “munin dm-cache”

Copyright (C) 2014 Vladimir Stackov amigo.elite@gmail.com

License

GPLv2

Magic Markers

#%# family=auto
#%# capabilities=autoconf suggest
#!/bin/bash
# -*- sh -*-

: << =cut

=head1 NAME

dm_cache_statistics_ - Wildcard-plugin to dm-cache statistics.

=head1 CONFIGURATION

This plugin does not normally require configuration.

The plugin may need to run as root to determine dm-cache status.
This is configured like this:

  [dm_cache_*]
	  user root

This is a wildcard plugin. To monitor a cached device-mapper volume,
link volume to this file. For example,

  ln -s /usr/share/munin/plugins/dm_cache_statistics_ \
        /etc/munin/plugins/dm_cache_statistics_vg_1122____lv_home

will monitor vg_1122-lv_home.

Please note that ____ (4 underscores) is replaced by - (dash) symbol.
This is workaround for http://munin-monitoring.org/ticket/1236

Cached volumes found in dmsetup status can be monitored.

=head1 AUTHOR

Original idea: Steinar H. Gunderson <sgunderson@bigfoot.com>
Found in Google by keywords "munin dm-cache"

Copyright (C) 2014 Vladimir Stackov <amigo.elite@gmail.com>

=head1 LICENSE

GPLv2

=head1 MAGIC MARKERS

 #%# family=auto
 #%# capabilities=autoconf suggest

=cut

CVOL=${0##*dm_cache_statistics_}
#workaround for http://munin-monitoring.org/ticket/1236
while [[ $CVOL == *"____"* ]]
do
	CVOL=${CVOL/____/-}
done

case $1 in
	autoconf)
		env dmsetup status > /dev/null 2>&1
		if [[ $? -eq 0 ]]; then
			echo yes
			exit 0
		else
			echo "no (env dmsetup returned value > 0)"
			exit 0
		fi
		;;
	suggest)
		dmsetup status | grep ' cache ' | awk -F: '{print $1}'
		exit $?
		;;
	config)
		echo "graph_title $CVOL dm-cache cache statistics"
		echo 'graph_args --base 1000'
		echo 'graph_vlabel blocks/sec'
		echo 'graph_category disk'
		echo "graph_info This graph shows the dm-cache cache statistics of the $CVOL cached volume."

		echo 'cache_read_hits.type DERIVE'
		echo 'cache_read_hits.label Read hits'
		echo 'cache_read_hits.info Read hits for cache'

		echo 'cache_read_misses.type DERIVE'
		echo 'cache_read_misses.label Read misses'
		echo 'cache_read_misses.info Read misses for cache'

		echo 'cache_write_hits.type DERIVE'
		echo 'cache_write_hits.label Write hits'
		echo 'cache_write_hits.info Write hits for cache'

		echo 'cache_write_misses.type DERIVE'
		echo 'cache_write_misses.label Write misses'
		echo 'cache_write_misses.info Write misses for cache'

		echo 'cache_demotions.type DERIVE'
		echo 'cache_demotions.label Demotions'
		echo 'cache_demotions.info Demotions for cache'

		echo 'cache_promotions.type DERIVE'
		echo 'cache_promotions.label Promotions'
		echo 'cache_promotions.info Promotions for cache'

		exit 0
		;;
esac

dmstatus=$(dmsetup status $CVOL)

echo "cache_read_hits.value $(echo $dmstatus | awk '{print $8}')"
echo "cache_read_misses.value $(echo $dmstatus | awk '{print $9}')"
echo "cache_write_hits.value $(echo $dmstatus | awk '{print $10}')"
echo "cache_write_misses.value $(echo $dmstatus | awk '{print $11}')"
echo "cache_demotions.value $(echo $dmstatus | awk '{print $12}')"
echo "cache_promotions.value $(echo $dmstatus | awk '{print $13}')"