1 # -*- coding: utf-8 -*-
3 # Copyright 2018 Whitestack, LLC
4 # *************************************************************
6 # This file is part of OSM Monitoring module
7 # All Rights Reserved to Whitestack, LLC
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
13 # http://www.apache.org/licenses/LICENSE-2.0
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
20 # For those usages not covered by the Apache License, Version 2.0 please
21 # contact: bdiaz@whitestack.com or glavado@whitestack.com
25 from typing
import Dict
29 from osm_mon
.core
.config
import Config
30 from osm_mon
.evaluator
.backends
.base
import BaseBackend
32 log
= logging
.getLogger(__name__
)
34 OSM_METRIC_PREFIX
= 'osm_'
37 class PrometheusBackend(BaseBackend
):
39 def __init__(self
, config
: Config
):
40 super().__init
__(config
)
43 def get_metric_value(self
, metric_name
: str, tags
: dict):
44 query
= self
._build
_query
(metric_name
, tags
)
45 request_url
= self
._build
_url
(query
)
46 request_headers
= self
._build
_headers
()
47 return self
._query
_metric
(request_url
, request_headers
)
49 def _query_metric(self
, request_url
: str, headers
: Dict
[str, str]):
50 log
.info("Querying Prometheus: %s", request_url
)
53 timeout
=int(self
.conf
.get("global", "request_timeout")),
56 if r
.status_code
== 200:
57 json_response
= r
.json()
58 if json_response
['status'] == 'success':
59 return self
._get
_metric
_value
_from
_response
(json_response
)
61 log
.warning("Prometheus response is not success. Got status %s", json_response
['status'])
63 log
.warning("Error contacting Prometheus. Got status code %s: %s", r
.status_code
, r
.text
)
66 def _build_query(self
, metric_name
: str, tags
: dict) -> str:
67 query_section_tags
= []
68 for k
, v
in tags
.items():
69 query_section_tags
.append(k
+ '=\"' + v
+ '\"')
70 query_section
= "query={0}{{{1}}}".format(OSM_METRIC_PREFIX
+ metric_name
, ','.join(query_section_tags
))
73 def _build_url(self
, query
: str):
74 return self
.conf
.get('prometheus', 'url') + "/api/v1/query?" + query
76 def _build_headers(self
) -> Dict
[str, str]:
78 user
= self
.conf
.get("prometheus", "user")
79 password
= self
.conf
.get("prometheus", "password")
81 _phrase
= f
"{user}:{password}".encode("utf-8")
82 token
= base64
.b64encode(_phrase
).decode("utf-8")
83 headers
["Authorization"] = f
"Basic {token}"
86 def _get_metric_value_from_response(self
, json_response
):
87 result
= json_response
['data']['result']
89 metric_value
= float(result
[0]['value'][1])
90 log
.info("Metric value: %s", metric_value
)