watcher.datasource.gnocchi

Source code for watcher.datasource.gnocchi

# -*- encoding: utf-8 -*-
# Copyright (c) 2017 Servionica
#
# Authors: Alexander Chadin <a.chadin@servionica.ru>
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
# implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from datetime import datetime
import time

from oslo_config import cfg
from oslo_log import log

from watcher.common import clients
from watcher.common import exception
from watcher.common import utils as common_utils

CONF = cfg.CONF
LOG = log.getLogger(__name__)


[docs]class GnocchiHelper(object): def __init__(self, osc=None): """:param osc: an OpenStackClients instance""" self.osc = osc if osc else clients.OpenStackClients() self.gnocchi = self.osc.gnocchi()
[docs] def query_retry(self, f, *args, **kwargs): for i in range(CONF.gnocchi_client.query_max_retries): try: return f(*args, **kwargs) except Exception as e: LOG.exception(e) time.sleep(CONF.gnocchi_client.query_timeout) raise
[docs] def statistic_aggregation(self, resource_id, metric, granularity, start_time=None, stop_time=None, aggregation='mean'): """Representing a statistic aggregate by operators :param metric: metric name of which we want the statistics :param resource_id: id of resource to list statistics for :param start_time: Start datetime from which metrics will be used :param stop_time: End datetime from which metrics will be used :param granularity: frequency of marking metric point, in seconds :param aggregation: Should be chosen in accordance with policy aggregations :return: value of aggregated metric """ if start_time is not None and not isinstance(start_time, datetime): raise exception.InvalidParameter(parameter='start_time', parameter_type=datetime) if stop_time is not None and not isinstance(stop_time, datetime): raise exception.InvalidParameter(parameter='stop_time', parameter_type=datetime) if not common_utils.is_uuid_like(resource_id): kwargs = dict(query={"=": {"original_resource_id": resource_id}}, limit=1) resources = self.query_retry( f=self.gnocchi.resource.search, **kwargs) if not resources: raise exception.ResourceNotFound(name=resource_id) resource_id = resources[0]['id'] raw_kwargs = dict( metric=metric, start=start_time, stop=stop_time, resource_id=resource_id, granularity=granularity, aggregation=aggregation, ) kwargs = {k: v for k, v in raw_kwargs.items() if k and v} statistics = self.query_retry( f=self.gnocchi.metric.get_measures, **kwargs) if statistics: # return value of latest measure # measure has structure [time, granularity, value] return statistics[-1][2]
Creative Commons Attribution 3.0 License

Except where otherwise noted, this document is licensed under Creative Commons Attribution 3.0 License. See all OpenStack Legal Documents.