2dffc1fc51
As stated in bug #1187833, there's no need to not record all of this events. We need to filter events on the state anyway. Also adding update events and documentation on how to enable them. Change-Id: Ic5845e1a3dc5ed531114e7ccdbe17bb98cb049fb Signed-off-by: Julien Danjou <julien@danjou.info>
187 lines
6.4 KiB
Python
187 lines
6.4 KiB
Python
# -*- encoding: utf-8 -*-
|
|
#
|
|
# Copyright © 2012 New Dream Network, LLC (DreamHost)
|
|
# Copyright © 2013 eNovance
|
|
#
|
|
# Author: Doug Hellmann <doug.hellmann@dreamhost.com>
|
|
# Julien Danjou <julien@danjou.info>
|
|
#
|
|
# 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.
|
|
"""Converters for producing compute counter messages from notification events.
|
|
"""
|
|
|
|
from oslo.config import cfg
|
|
|
|
from ceilometer import counter
|
|
from ceilometer import plugin
|
|
|
|
|
|
OPTS = [
|
|
cfg.StrOpt('nova_control_exchange',
|
|
default='nova',
|
|
help="Exchange name for Nova notifications"),
|
|
]
|
|
|
|
|
|
cfg.CONF.register_opts(OPTS)
|
|
|
|
|
|
class ComputeNotificationBase(plugin.NotificationBase):
|
|
@staticmethod
|
|
def get_exchange_topics(conf):
|
|
"""Return a sequence of ExchangeTopics defining the exchange and
|
|
topics to be connected for this plugin.
|
|
"""
|
|
return [
|
|
plugin.ExchangeTopics(
|
|
exchange=conf.nova_control_exchange,
|
|
topics=set(topic + ".info"
|
|
for topic in conf.notification_topics)),
|
|
]
|
|
|
|
|
|
class InstanceScheduled(ComputeNotificationBase):
|
|
@staticmethod
|
|
def get_event_types():
|
|
return ['scheduler.run_instance.scheduled']
|
|
|
|
def process_notification(self, message):
|
|
yield counter.Counter.from_notification(
|
|
name='instance.scheduled',
|
|
type=counter.TYPE_DELTA,
|
|
volume=1,
|
|
unit='instance',
|
|
user_id=None,
|
|
project_id=
|
|
message['payload']['request_spec']
|
|
['instance_properties']['project_id'],
|
|
resource_id=message['payload']['instance_id'],
|
|
message=message)
|
|
|
|
|
|
class ComputeInstanceNotificationBase(ComputeNotificationBase):
|
|
"""Convert compute.instance.* notifications into Counters
|
|
"""
|
|
@staticmethod
|
|
def get_event_types():
|
|
return ['compute.instance.create.start',
|
|
'compute.instance.create.end',
|
|
'compute.instance.exists',
|
|
'compute.instance.update',
|
|
'compute.instance.delete.start',
|
|
'compute.instance.delete.end',
|
|
'compute.instance.finish_resize.end',
|
|
'compute.instance.resize.revert.end']
|
|
|
|
|
|
class Instance(ComputeInstanceNotificationBase):
|
|
def process_notification(self, message):
|
|
yield counter.Counter.from_notification(
|
|
name='instance',
|
|
type=counter.TYPE_GAUGE,
|
|
unit='instance',
|
|
volume=1,
|
|
user_id=message['payload']['user_id'],
|
|
project_id=message['payload']['tenant_id'],
|
|
resource_id=message['payload']['instance_id'],
|
|
message=message)
|
|
|
|
|
|
class Memory(ComputeInstanceNotificationBase):
|
|
def process_notification(self, message):
|
|
yield counter.Counter.from_notification(
|
|
name='memory',
|
|
type=counter.TYPE_GAUGE,
|
|
unit='MB',
|
|
volume=message['payload']['memory_mb'],
|
|
user_id=message['payload']['user_id'],
|
|
project_id=message['payload']['tenant_id'],
|
|
resource_id=message['payload']['instance_id'],
|
|
message=message)
|
|
|
|
|
|
class VCpus(ComputeInstanceNotificationBase):
|
|
def process_notification(self, message):
|
|
yield counter.Counter.from_notification(
|
|
name='vcpus',
|
|
type=counter.TYPE_GAUGE,
|
|
unit='vcpu',
|
|
volume=message['payload']['vcpus'],
|
|
user_id=message['payload']['user_id'],
|
|
project_id=message['payload']['tenant_id'],
|
|
resource_id=message['payload']['instance_id'],
|
|
message=message)
|
|
|
|
|
|
class RootDiskSize(ComputeInstanceNotificationBase):
|
|
def process_notification(self, message):
|
|
yield counter.Counter.from_notification(
|
|
name='disk.root.size',
|
|
type=counter.TYPE_GAUGE,
|
|
unit='GB',
|
|
volume=message['payload']['root_gb'],
|
|
user_id=message['payload']['user_id'],
|
|
project_id=message['payload']['tenant_id'],
|
|
resource_id=message['payload']['instance_id'],
|
|
message=message)
|
|
|
|
|
|
class EphemeralDiskSize(ComputeInstanceNotificationBase):
|
|
def process_notification(self, message):
|
|
yield counter.Counter.from_notification(
|
|
name='disk.ephemeral.size',
|
|
type=counter.TYPE_GAUGE,
|
|
unit='GB',
|
|
volume=message['payload']['ephemeral_gb'],
|
|
user_id=message['payload']['user_id'],
|
|
project_id=message['payload']['tenant_id'],
|
|
resource_id=message['payload']['instance_id'],
|
|
message=message)
|
|
|
|
|
|
class InstanceFlavor(ComputeInstanceNotificationBase):
|
|
def process_notification(self, message):
|
|
instance_type = message.get('payload', {}).get('instance_type')
|
|
if instance_type:
|
|
yield counter.Counter.from_notification(
|
|
name='instance:%s' % instance_type,
|
|
type=counter.TYPE_GAUGE,
|
|
unit='instance',
|
|
volume=1,
|
|
user_id=message['payload']['user_id'],
|
|
project_id=message['payload']['tenant_id'],
|
|
resource_id=message['payload']['instance_id'],
|
|
message=message)
|
|
|
|
|
|
class InstanceDelete(ComputeInstanceNotificationBase):
|
|
"""Handle the messages sent by the nova notifier plugin
|
|
when an instance is being deleted.
|
|
"""
|
|
|
|
@staticmethod
|
|
def get_event_types():
|
|
return ['compute.instance.delete.samples']
|
|
|
|
def process_notification(self, message):
|
|
for sample in message['payload'].get('samples', []):
|
|
yield counter.Counter.from_notification(
|
|
name=sample['name'],
|
|
type=sample['type'],
|
|
unit=sample['unit'],
|
|
volume=sample['volume'],
|
|
user_id=message['payload']['user_id'],
|
|
project_id=message['payload']['tenant_id'],
|
|
resource_id=message['payload']['instance_id'],
|
|
message=message)
|