Repository
Munin (contrib)
Last change
2018-08-02
Graph Categories
Family
auto
Capabilities
Keywords
Language
Python (2.x)

nova_instance_timing

Sadly there is no documentation for this plugin.

#!/usr/bin/env python
#
# Plugin to monitor trending of launch/schedule times for last 5 successful instances
#
# To monitor a floating ips, link floating_ips to this file.
# E.g.
#    ln -s /usr/share/munin/plugins/nova_instance_timing /etc/munin/plugins/
#
# Needs following minimal configuration in plugin-conf.d/nova:
#   [nova_*]
#   user nova
#
# Magic markers
#%# capabilities=autoconf
#%# family=auto

import sys

try:
    from nova import context
    from nova import db
    from nova import flags
    from nova import utils
    from nova.db.sqlalchemy.session import get_session
except ImportError:
    successful_import = False
else:
    successful_import = True


def print_config():
    global states
    print 'graph_title Nova Launch Times'
    print 'graph_vlabel seconds'
    print 'graph_args --base 1000 --lower-limit 0'
    print 'graph_category cloud'
    print 'graph_scale no'
    print 'graph_info This the average time for the last 5 schedulings/launchings'
    print 'schedule.label schedule time'
    print 'schedule.draw LINE2'
    print 'schedule.info average time for last 5 instance to be scheduled'
    print 'launch.label launch time'
    print 'launch.draw LINE2'
    print 'launch.info average time for last 5 instance to be launched after scheduling'


def get_status():
    connection = get_session().connection()
    row = connection.execute("select AVG(TIME_TO_SEC(TIMEDIFF(scheduled_at, created_at))) from instances where scheduled_at is not null order by scheduled_at desc limit 5;").fetchall()[0]
    schedule = row[0]
    row = connection.execute("select AVG(TIME_TO_SEC(TIMEDIFF(launched_at, scheduled_at))) from instances where launched_at is not null order by launched_at desc limit 5;").fetchall()[0]
    launch = row[0]
    return (schedule, launch)


def print_values():
    schedule, launch = get_status()
    print "schedule.value %s" % schedule
    print "launch.value %s" % launch


if __name__ == '__main__':
    if len(sys.argv) > 1:
        if sys.argv[1] == "config":
            print_config()
        elif sys.argv[1] == "autoconf":
            if not successful_import:
                print 'no (failed import nova module)'
                sys.exit(0)
            else:
                print 'yes'
    elif successful_import:
        utils.default_flagfile()
        flags.FLAGS(sys.argv)
        print_values()