blob: 1bc3ff466dce27c513725b4f0c552c7aaa53b51b [file] [log] [blame]
Benjamin Diaz0e342442018-11-09 17:52:08 -03001# -*- coding: utf-8 -*-
2
3# Copyright 2018 Whitestack, LLC
4# *************************************************************
5
6# This file is part of OSM Monitoring module
7# All Rights Reserved to Whitestack, LLC
8
9# Licensed under the Apache License, Version 2.0 (the "License"); you may
10# not use this file except in compliance with the License. You may obtain
11# a copy of the License at
12
13# http://www.apache.org/licenses/LICENSE-2.0
14
15# Unless required by applicable law or agreed to in writing, software
16# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
17# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
18# License for the specific language governing permissions and limitations
19# under the License.
20# For those usages not covered by the Apache License, Version 2.0 please
21# contact: bdiaz@whitestack.com or glavado@whitestack.com
22##
23import logging
24from typing import List
25
26from prometheus_client import start_http_server
27from prometheus_client.core import REGISTRY, GaugeMetricFamily
28
29from osm_mon.collector.backends.base import BaseBackend
30from osm_mon.collector.metric import Metric
31
32log = logging.getLogger(__name__)
33
34OSM_METRIC_PREFIX = 'osm_'
35
36
37class PrometheusBackend(BaseBackend):
38
39 def __init__(self):
40 self.custom_collector = CustomCollector()
41 self._start_exporter(8000)
42
43 def handle(self, metrics: List[Metric]):
Benjamin Diaz51f44862018-11-15 10:27:12 -030044 log.debug('handle')
45 log.debug('metrics: %s', metrics)
Benjamin Diaz0e342442018-11-09 17:52:08 -030046 prometheus_metrics = []
47 for metric in metrics:
48 prometheus_metric = GaugeMetricFamily(
49 OSM_METRIC_PREFIX + metric.name,
50 'OSM metric',
51 labels=['ns_id', 'vnf_member_index', 'vdu_name']
52 )
53 prometheus_metric.add_metric([metric.nsr_id, metric.vnf_member_index, metric.vdur_name], metric.value)
54 prometheus_metrics.append(prometheus_metric)
55 self.custom_collector.metrics = prometheus_metrics
56
57 def _start_exporter(self, port):
58 log.debug('_start_exporter')
Benjamin Diaz51f44862018-11-15 10:27:12 -030059 log.debug('port: %s', port)
Benjamin Diaz0e342442018-11-09 17:52:08 -030060 REGISTRY.register(self.custom_collector)
61 log.info("Starting MON Prometheus exporter at port %s", port)
62 start_http_server(port)
63
64
65class CustomCollector(object):
66
67 def __init__(self):
68 self.metrics = []
69
70 def describe(self):
71 log.debug('describe')
72 return []
73
74 def collect(self):
75 log.debug("collect")
76 return self.metrics