glances_rabbitmq.py 4.1 KB
Newer Older
K
Katyucha 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
# -*- coding: utf-8 -*-
#
# This file is part of Glances.
#
# Copyright (C) 2015 Nicolargo <nicolas@nicolargo.com>
#
# Glances is free software; you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Glances is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.

"""JMS interface class."""

# Import sys libs
A
flake8  
Alessio Sergi 已提交
23 24 25
import datetime
import socket
import sys
K
Katyucha 已提交
26 27 28 29
from numbers import Number

# Import Glances lib
from glances.core.glances_logging import logger
30 31 32 33
try:
    from configparser import NoOptionError, NoSectionError
except ImportError:  # Python 2
    from ConfigParser import NoOptionError, NoSectionError
K
Katyucha 已提交
34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
from glances.exports.glances_export import GlancesExport

# Import pika for RabbitMQ
import pika


class Export(GlancesExport):

    """This class manages the rabbitMQ export module."""

    def __init__(self, config=None, args=None):
        """Init the RabbitMQ export IF."""
        GlancesExport.__init__(self, config=config, args=args)

        # Load the rabbitMQ configuration file
        self.rabbitmq_host = None
        self.rabbitmq_port = None
        self.rabbitmq_user = None
        self.rabbitmq_password = None
        self.rabbitmq_queue = None
K
Katyucha 已提交
54
        self.hostname = socket.gethostname()
K
Katyucha 已提交
55 56 57 58 59 60 61 62
        self.export_enable = self.load_conf()
        if not self.export_enable:
            sys.exit(2)

        # Init the rabbitmq client
        self.client = self.init()

    def load_conf(self, section="rabbitmq"):
A
PEP 257  
Alessio Sergi 已提交
63
        """Load the rabbitmq configuration in the Glances configuration file."""
K
Katyucha 已提交
64 65 66
        if self.config is None:
            return False
        try:
67 68 69 70 71
            self.rabbitmq_host = self.config.get_value(section, 'host')
            self.rabbitmq_port = self.config.get_value(section, 'port')
            self.rabbitmq_user = self.config.get_value(section, 'user')
            self.rabbitmq_password = self.config.get_value(section, 'password')
            self.rabbitmq_queue = self.config.get_value(section, 'queue')
K
Katyucha 已提交
72 73 74 75 76 77 78 79 80 81 82
        except NoSectionError:
            logger.critical("No rabbitmq configuration found")
            return False
        except NoOptionError as e:
            logger.critical("Error in the RabbitM configuration (%s)" % e)
            return False
        else:
            logger.debug("Load RabbitMQ from the Glances configuration file")
        return True

    def init(self):
A
PEP 257  
Alessio Sergi 已提交
83
        """Init the connection to the rabbitmq server."""
K
Katyucha 已提交
84 85
        if not self.export_enable:
            return None
86
        try:
A
flake8  
Alessio Sergi 已提交
87 88 89 90 91
                parameters = pika.URLParameters(
                    'amqp://' + self.rabbitmq_user +
                    ':' + self.rabbitmq_password +
                    '@' + self.rabbitmq_host +
                    ':' + self.rabbitmq_port + '/')
K
Katyucha 已提交
92 93 94 95
                connection = pika.BlockingConnection(parameters)
                channel = connection.channel()
                return channel
        except Exception as e:
96
                logger.critical("Connection to rabbitMQ failed : %s " % e)
K
Katyucha 已提交
97
                return None
K
Katyucha 已提交
98 99

    def export(self, name, columns, points):
A
PEP 257  
Alessio Sergi 已提交
100
        """Write the points in RabbitMQ."""
A
flake8  
Alessio Sergi 已提交
101 102
        data = ('hostname=' + self.hostname + ', name=' + name +
                ', dateinfo=' + datetime.datetime.utcnow().isoformat())
K
Katyucha 已提交
103
        for i in range(0, len(columns)):
K
Katyucha 已提交
104 105
            if not isinstance(points[i], Number):
                continue
K
Katyucha 已提交
106
            else:
107
                data += ", " + columns[i] + "=" + str(points[i])
K
Katyucha 已提交
108
        logger.debug(data)
K
Katyucha 已提交
109
        try:
110
            self.client.basic_publish(exchange='', routing_key=self.rabbitmq_queue, body=data)
K
Katyucha 已提交
111 112
        except Exception as e:
            logger.error("Can not export stats to RabbitMQ (%s)" % e)