Remove Windows OS support
It was deprecated during the previous cycle because of retired WinStackers project[1]. The following pollsters are also removed because these are supported only by Hyper-V inspector. - disk.device.latency - disk.device.iops [1] 7660339b4a4d578f2615fd6c27e8c9627ab29d37 Change-Id: I872f93b945233a1288c773302be3835db2fd2e4f
This commit is contained in:
parent
a6e43add90
commit
3b8adafbb0
@ -14,7 +14,6 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import os
|
|
||||||
import shlex
|
import shlex
|
||||||
|
|
||||||
import cotyledon
|
import cotyledon
|
||||||
@ -89,16 +88,8 @@ def create_polling_service(worker_id, conf=None):
|
|||||||
|
|
||||||
def main():
|
def main():
|
||||||
sm = cotyledon.ServiceManager()
|
sm = cotyledon.ServiceManager()
|
||||||
# On Windows, we can only initialize conf objects in the subprocess.
|
conf = _prepare_config()
|
||||||
# As a consequence, we can't use oslo_config_glue.setup() on Windows,
|
priv_context.init(root_helper=shlex.split(utils._get_root_helper()))
|
||||||
# because cotyledon.ServiceManager objects are not picklable.
|
oslo_config_glue.setup(sm, conf)
|
||||||
if os.name == 'nt':
|
sm.add(create_polling_service, args=(conf,))
|
||||||
LOG.warning("Support for Ceilometer on Windows operating systems is"
|
|
||||||
"deprecated.")
|
|
||||||
sm.add(create_polling_service)
|
|
||||||
else:
|
|
||||||
conf = _prepare_config()
|
|
||||||
priv_context.init(root_helper=shlex.split(utils._get_root_helper()))
|
|
||||||
oslo_config_glue.setup(sm, conf)
|
|
||||||
sm.add(create_polling_service, args=(conf,))
|
|
||||||
sm.run()
|
sm.run()
|
||||||
|
@ -58,20 +58,6 @@ class PerDeviceWriteBytesPollster(PerDeviceDiskPollster):
|
|||||||
sample_stats_key = 'write_bytes'
|
sample_stats_key = 'write_bytes'
|
||||||
|
|
||||||
|
|
||||||
class PerDeviceDiskLatencyPollster(PerDeviceDiskPollster):
|
|
||||||
inspector_method = 'inspect_disk_latency'
|
|
||||||
sample_name = 'disk.device.latency'
|
|
||||||
sample_unit = 'ms'
|
|
||||||
sample_stats_key = 'disk_latency'
|
|
||||||
|
|
||||||
|
|
||||||
class PerDeviceDiskIOPSPollster(PerDeviceDiskPollster):
|
|
||||||
inspector_method = 'inspect_disk_iops'
|
|
||||||
sample_name = 'disk.device.iops'
|
|
||||||
sample_unit = 'count/s'
|
|
||||||
sample_stats_key = 'iops_count'
|
|
||||||
|
|
||||||
|
|
||||||
class PerDeviceCapacityPollster(PerDeviceDiskPollster):
|
class PerDeviceCapacityPollster(PerDeviceDiskPollster):
|
||||||
inspector_method = 'inspect_disk_info'
|
inspector_method = 'inspect_disk_info'
|
||||||
sample_name = 'disk.device.capacity'
|
sample_name = 'disk.device.capacity'
|
||||||
|
@ -1,161 +0,0 @@
|
|||||||
# Copyright 2013 Cloudbase Solutions Srl
|
|
||||||
#
|
|
||||||
# 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.
|
|
||||||
"""Implementation of Inspector abstraction for Hyper-V"""
|
|
||||||
|
|
||||||
import collections
|
|
||||||
import functools
|
|
||||||
import sys
|
|
||||||
import warnings
|
|
||||||
|
|
||||||
from os_win import exceptions as os_win_exc
|
|
||||||
from os_win import utilsfactory
|
|
||||||
from oslo_utils import units
|
|
||||||
|
|
||||||
from ceilometer.compute.pollsters import util
|
|
||||||
from ceilometer.compute.virt import inspector as virt_inspector
|
|
||||||
|
|
||||||
|
|
||||||
def convert_exceptions(exception_map, yields=True):
|
|
||||||
expected_exceptions = tuple(exception_map.keys())
|
|
||||||
|
|
||||||
def _reraise_exception(exc):
|
|
||||||
# exception might be a subclass of an expected exception.
|
|
||||||
for expected in expected_exceptions:
|
|
||||||
if isinstance(exc, expected):
|
|
||||||
raised_exception = exception_map[expected]
|
|
||||||
break
|
|
||||||
|
|
||||||
exc_info = sys.exc_info()
|
|
||||||
exc = raised_exception(str(exc_info[1]))
|
|
||||||
raise exc.with_traceback(exc_info[2])
|
|
||||||
|
|
||||||
def decorator(function):
|
|
||||||
if yields:
|
|
||||||
@functools.wraps(function)
|
|
||||||
def wrapper(*args, **kwargs):
|
|
||||||
try:
|
|
||||||
# NOTE(claudiub): We're consuming the function's yield in
|
|
||||||
# order to avoid yielding a generator.
|
|
||||||
for item in function(*args, **kwargs):
|
|
||||||
yield item
|
|
||||||
except expected_exceptions as ex:
|
|
||||||
_reraise_exception(ex)
|
|
||||||
else:
|
|
||||||
@functools.wraps(function)
|
|
||||||
def wrapper(*args, **kwargs):
|
|
||||||
try:
|
|
||||||
return function(*args, **kwargs)
|
|
||||||
except expected_exceptions as ex:
|
|
||||||
_reraise_exception(ex)
|
|
||||||
|
|
||||||
return wrapper
|
|
||||||
return decorator
|
|
||||||
|
|
||||||
|
|
||||||
exception_conversion_map = collections.OrderedDict([
|
|
||||||
# NOTE(claudiub): order should be from the most specialized exception type
|
|
||||||
# to the most generic exception type.
|
|
||||||
# (expected_exception, converted_exception)
|
|
||||||
(os_win_exc.NotFound, virt_inspector.InstanceNotFoundException),
|
|
||||||
(os_win_exc.OSWinException, virt_inspector.InspectorException),
|
|
||||||
])
|
|
||||||
|
|
||||||
# NOTE(claudiub): the purpose of the decorators below is to prevent any
|
|
||||||
# os_win exceptions (subclasses of OSWinException) to leak outside of the
|
|
||||||
# HyperVInspector.
|
|
||||||
|
|
||||||
|
|
||||||
class HyperVInspector(virt_inspector.Inspector):
|
|
||||||
|
|
||||||
def __init__(self, conf):
|
|
||||||
super(HyperVInspector, self).__init__(conf)
|
|
||||||
self._utils = utilsfactory.get_metricsutils()
|
|
||||||
self._host_max_cpu_clock = self._compute_host_max_cpu_clock()
|
|
||||||
|
|
||||||
warnings.warn('Support for HyperV is deprecated.',
|
|
||||||
category=DeprecationWarning, stacklevel=2)
|
|
||||||
|
|
||||||
def _compute_host_max_cpu_clock(self):
|
|
||||||
hostutils = utilsfactory.get_hostutils()
|
|
||||||
# host's number of CPUs and CPU clock speed will not change.
|
|
||||||
cpu_info = hostutils.get_cpus_info()
|
|
||||||
host_cpu_count = len(cpu_info)
|
|
||||||
host_cpu_clock = cpu_info[0]['MaxClockSpeed']
|
|
||||||
|
|
||||||
return float(host_cpu_clock * host_cpu_count)
|
|
||||||
|
|
||||||
@convert_exceptions(exception_conversion_map, yields=False)
|
|
||||||
def inspect_instance(self, instance, duration):
|
|
||||||
instance_name = util.instance_name(instance)
|
|
||||||
(cpu_clock_used,
|
|
||||||
cpu_count, uptime) = self._utils.get_cpu_metrics(instance_name)
|
|
||||||
cpu_percent_used = cpu_clock_used / self._host_max_cpu_clock
|
|
||||||
# Nanoseconds
|
|
||||||
cpu_time = (int(uptime * cpu_percent_used) * units.k)
|
|
||||||
memory_usage = self._utils.get_memory_metrics(instance_name)
|
|
||||||
|
|
||||||
return virt_inspector.InstanceStats(
|
|
||||||
cpu_number=cpu_count,
|
|
||||||
cpu_time=cpu_time,
|
|
||||||
memory_usage=memory_usage)
|
|
||||||
|
|
||||||
@convert_exceptions(exception_conversion_map)
|
|
||||||
def inspect_vnics(self, instance, duration):
|
|
||||||
instance_name = util.instance_name(instance)
|
|
||||||
for vnic_metrics in self._utils.get_vnic_metrics(instance_name):
|
|
||||||
yield virt_inspector.InterfaceStats(
|
|
||||||
name=vnic_metrics["element_name"],
|
|
||||||
mac=vnic_metrics["address"],
|
|
||||||
fref=None,
|
|
||||||
parameters=None,
|
|
||||||
rx_bytes=vnic_metrics['rx_mb'] * units.Mi,
|
|
||||||
rx_packets=0,
|
|
||||||
rx_drop=0,
|
|
||||||
rx_errors=0,
|
|
||||||
tx_bytes=vnic_metrics['tx_mb'] * units.Mi,
|
|
||||||
tx_packets=0,
|
|
||||||
tx_drop=0,
|
|
||||||
tx_errors=0,
|
|
||||||
rx_bytes_delta=0,
|
|
||||||
tx_bytes_delta=0)
|
|
||||||
|
|
||||||
@convert_exceptions(exception_conversion_map)
|
|
||||||
def inspect_disks(self, instance, duration):
|
|
||||||
instance_name = util.instance_name(instance)
|
|
||||||
for disk_metrics in self._utils.get_disk_metrics(instance_name):
|
|
||||||
yield virt_inspector.DiskStats(
|
|
||||||
device=disk_metrics['instance_id'],
|
|
||||||
read_requests=0,
|
|
||||||
# Return bytes
|
|
||||||
read_bytes=disk_metrics['read_mb'] * units.Mi,
|
|
||||||
write_requests=0,
|
|
||||||
write_bytes=disk_metrics['write_mb'] * units.Mi,
|
|
||||||
errors=0, wr_total_times=0, rd_total_times=0)
|
|
||||||
|
|
||||||
@convert_exceptions(exception_conversion_map)
|
|
||||||
def inspect_disk_latency(self, instance, duration):
|
|
||||||
instance_name = util.instance_name(instance)
|
|
||||||
for disk_metrics in self._utils.get_disk_latency_metrics(
|
|
||||||
instance_name):
|
|
||||||
yield virt_inspector.DiskLatencyStats(
|
|
||||||
device=disk_metrics['instance_id'],
|
|
||||||
disk_latency=disk_metrics['disk_latency'] / 1000)
|
|
||||||
|
|
||||||
@convert_exceptions(exception_conversion_map)
|
|
||||||
def inspect_disk_iops(self, instance, duration):
|
|
||||||
instance_name = util.instance_name(instance)
|
|
||||||
for disk_metrics in self._utils.get_disk_iops_count(instance_name):
|
|
||||||
yield virt_inspector.DiskIOPSStats(
|
|
||||||
device=disk_metrics['instance_id'],
|
|
||||||
iops_count=disk_metrics['iops_count'])
|
|
@ -27,7 +27,7 @@ OPTS = [
|
|||||||
cfg.StrOpt('hypervisor_inspector',
|
cfg.StrOpt('hypervisor_inspector',
|
||||||
default='libvirt',
|
default='libvirt',
|
||||||
help='Inspector to use for inspecting the hypervisor layer. '
|
help='Inspector to use for inspecting the hypervisor layer. '
|
||||||
'Known inspectors are libvirt, hyperv, and vsphere.'),
|
'Known inspectors are libvirt and vsphere.'),
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
@ -129,21 +129,6 @@ DiskRateStats = collections.namedtuple('DiskRateStats',
|
|||||||
'write_bytes_rate',
|
'write_bytes_rate',
|
||||||
'write_requests_rate'])
|
'write_requests_rate'])
|
||||||
|
|
||||||
# Named tuple representing disk latency statistics.
|
|
||||||
#
|
|
||||||
# disk_latency: average disk latency
|
|
||||||
#
|
|
||||||
DiskLatencyStats = collections.namedtuple('DiskLatencyStats',
|
|
||||||
['device', 'disk_latency'])
|
|
||||||
|
|
||||||
# Named tuple representing disk iops statistics.
|
|
||||||
#
|
|
||||||
# iops: number of iops per second
|
|
||||||
#
|
|
||||||
DiskIOPSStats = collections.namedtuple('DiskIOPSStats',
|
|
||||||
['device', 'iops_count'])
|
|
||||||
|
|
||||||
|
|
||||||
# Named tuple representing disk Information.
|
# Named tuple representing disk Information.
|
||||||
#
|
#
|
||||||
# capacity: capacity of the disk
|
# capacity: capacity of the disk
|
||||||
@ -237,26 +222,6 @@ class Inspector(object):
|
|||||||
"""
|
"""
|
||||||
raise ceilometer.NotImplementedError
|
raise ceilometer.NotImplementedError
|
||||||
|
|
||||||
def inspect_disk_latency(self, instance, duration):
|
|
||||||
"""Inspect the disk statistics as rates for an instance.
|
|
||||||
|
|
||||||
:param instance: the target instance
|
|
||||||
:param duration: the last 'n' seconds, over which the value should be
|
|
||||||
inspected
|
|
||||||
:return: for each disk, the average disk latency
|
|
||||||
"""
|
|
||||||
raise ceilometer.NotImplementedError
|
|
||||||
|
|
||||||
def inspect_disk_iops(self, instance, duration):
|
|
||||||
"""Inspect the disk statistics as rates for an instance.
|
|
||||||
|
|
||||||
:param instance: the target instance
|
|
||||||
:param duration: the last 'n' seconds, over which the value should be
|
|
||||||
inspected
|
|
||||||
:return: for each disk, the number of iops per second
|
|
||||||
"""
|
|
||||||
raise ceilometer.NotImplementedError
|
|
||||||
|
|
||||||
def inspect_disk_info(self, instance, duration):
|
def inspect_disk_info(self, instance, duration):
|
||||||
"""Inspect the disk information for an instance.
|
"""Inspect the disk information for an instance.
|
||||||
|
|
||||||
|
@ -156,10 +156,8 @@ resources:
|
|||||||
archive_policy_name: ceilometer-low-rate
|
archive_policy_name: ceilometer-low-rate
|
||||||
disk.device.write.bytes:
|
disk.device.write.bytes:
|
||||||
archive_policy_name: ceilometer-low-rate
|
archive_policy_name: ceilometer-low-rate
|
||||||
disk.device.latency:
|
|
||||||
disk.device.read.latency:
|
disk.device.read.latency:
|
||||||
disk.device.write.latency:
|
disk.device.write.latency:
|
||||||
disk.device.iops:
|
|
||||||
disk.device.capacity:
|
disk.device.capacity:
|
||||||
disk.device.allocation:
|
disk.device.allocation:
|
||||||
disk.device.usage:
|
disk.device.usage:
|
||||||
|
@ -164,47 +164,6 @@ class TestDiskPollsters(TestBaseDiskIO):
|
|||||||
'disk.device.write.latency', 400, 'vda2')
|
'disk.device.write.latency', 400, 'vda2')
|
||||||
|
|
||||||
|
|
||||||
class TestDiskLatencyPollsters(TestBaseDiskIO):
|
|
||||||
|
|
||||||
DISKS = [
|
|
||||||
virt_inspector.DiskLatencyStats("disk1", 1),
|
|
||||||
virt_inspector.DiskLatencyStats("disk2", 2)
|
|
||||||
]
|
|
||||||
TYPE = 'gauge'
|
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
super(TestDiskLatencyPollsters, self).setUp()
|
|
||||||
self.inspector.inspect_disk_latency = mock.Mock(
|
|
||||||
return_value=self.DISKS)
|
|
||||||
|
|
||||||
def test_per_device_latency(self):
|
|
||||||
self._check_per_device_samples(disk.PerDeviceDiskLatencyPollster,
|
|
||||||
'disk.device.latency', 1, 'disk1')
|
|
||||||
|
|
||||||
self._check_per_device_samples(disk.PerDeviceDiskLatencyPollster,
|
|
||||||
'disk.device.latency', 2, 'disk2')
|
|
||||||
|
|
||||||
|
|
||||||
class TestDiskIOPSPollsters(TestBaseDiskIO):
|
|
||||||
|
|
||||||
DISKS = [
|
|
||||||
virt_inspector.DiskIOPSStats("disk1", 10),
|
|
||||||
virt_inspector.DiskIOPSStats("disk2", 20),
|
|
||||||
]
|
|
||||||
TYPE = 'gauge'
|
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
super(TestDiskIOPSPollsters, self).setUp()
|
|
||||||
self.inspector.inspect_disk_iops = mock.Mock(return_value=self.DISKS)
|
|
||||||
|
|
||||||
def test_per_device_iops(self):
|
|
||||||
self._check_per_device_samples(disk.PerDeviceDiskIOPSPollster,
|
|
||||||
'disk.device.iops', 10, 'disk1')
|
|
||||||
|
|
||||||
self._check_per_device_samples(disk.PerDeviceDiskIOPSPollster,
|
|
||||||
'disk.device.iops', 20, 'disk2')
|
|
||||||
|
|
||||||
|
|
||||||
class TestDiskInfoPollsters(TestBaseDiskIO):
|
class TestDiskInfoPollsters(TestBaseDiskIO):
|
||||||
|
|
||||||
DISKS = [
|
DISKS = [
|
||||||
|
@ -1,212 +0,0 @@
|
|||||||
# Copyright 2013 Cloudbase Solutions Srl
|
|
||||||
#
|
|
||||||
# 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.
|
|
||||||
"""
|
|
||||||
Tests for Hyper-V inspector.
|
|
||||||
"""
|
|
||||||
|
|
||||||
import sys
|
|
||||||
from unittest import mock
|
|
||||||
|
|
||||||
from os_win import exceptions as os_win_exc
|
|
||||||
from oslo_utils import units
|
|
||||||
from oslotest import base
|
|
||||||
|
|
||||||
from ceilometer.compute.virt.hyperv import inspector as hyperv_inspector
|
|
||||||
from ceilometer.compute.virt import inspector as virt_inspector
|
|
||||||
from ceilometer import service
|
|
||||||
|
|
||||||
|
|
||||||
class TestHyperVInspection(base.BaseTestCase):
|
|
||||||
|
|
||||||
@mock.patch.object(hyperv_inspector, 'utilsfactory', mock.MagicMock())
|
|
||||||
@mock.patch.object(hyperv_inspector.HyperVInspector,
|
|
||||||
'_compute_host_max_cpu_clock')
|
|
||||||
def setUp(self, mock_compute_host_cpu_clock):
|
|
||||||
conf = service.prepare_service([], [])
|
|
||||||
self._inspector = hyperv_inspector.HyperVInspector(conf)
|
|
||||||
self._inspector._utils = mock.MagicMock()
|
|
||||||
|
|
||||||
super(TestHyperVInspection, self).setUp()
|
|
||||||
|
|
||||||
def test_converted_exception(self):
|
|
||||||
self._inspector._utils.get_cpu_metrics.side_effect = (
|
|
||||||
os_win_exc.OSWinException)
|
|
||||||
self.assertRaises(virt_inspector.InspectorException,
|
|
||||||
self._inspector.inspect_instance,
|
|
||||||
mock.sentinel.instance, None)
|
|
||||||
|
|
||||||
self._inspector._utils.get_cpu_metrics.side_effect = (
|
|
||||||
os_win_exc.HyperVException)
|
|
||||||
self.assertRaises(virt_inspector.InspectorException,
|
|
||||||
self._inspector.inspect_instance,
|
|
||||||
mock.sentinel.instance, None)
|
|
||||||
|
|
||||||
self._inspector._utils.get_cpu_metrics.side_effect = (
|
|
||||||
os_win_exc.NotFound(resource='foofoo'))
|
|
||||||
self.assertRaises(virt_inspector.InstanceNotFoundException,
|
|
||||||
self._inspector.inspect_instance,
|
|
||||||
mock.sentinel.instance, None)
|
|
||||||
|
|
||||||
def _yield_consumer(generator_method, *args, **kwargs):
|
|
||||||
list(generator_method(*args, **kwargs))
|
|
||||||
|
|
||||||
self._inspector._utils.get_vnic_metrics.side_effect = (
|
|
||||||
os_win_exc.OSWinException)
|
|
||||||
self.assertRaises(virt_inspector.InspectorException,
|
|
||||||
_yield_consumer, self._inspector.inspect_vnics,
|
|
||||||
mock.sentinel.instance, None)
|
|
||||||
|
|
||||||
self._inspector._utils.get_vnic_metrics.side_effect = (
|
|
||||||
os_win_exc.HyperVException)
|
|
||||||
self.assertRaises(virt_inspector.InspectorException,
|
|
||||||
_yield_consumer, self._inspector.inspect_vnics,
|
|
||||||
mock.sentinel.instance, None)
|
|
||||||
|
|
||||||
self._inspector._utils.get_vnic_metrics.side_effect = (
|
|
||||||
os_win_exc.NotFound(resource='foofoo'))
|
|
||||||
self.assertRaises(virt_inspector.InstanceNotFoundException,
|
|
||||||
_yield_consumer, self._inspector.inspect_vnics,
|
|
||||||
mock.sentinel.instance, None)
|
|
||||||
|
|
||||||
def test_assert_original_traceback_maintained(self):
|
|
||||||
def bar(self):
|
|
||||||
foo = "foofoo"
|
|
||||||
raise os_win_exc.NotFound(resource=foo)
|
|
||||||
|
|
||||||
self._inspector._utils.get_cpu_metrics.side_effect = bar
|
|
||||||
try:
|
|
||||||
self._inspector.inspect_instance(mock.sentinel.instance, None)
|
|
||||||
self.fail("Test expected exception, but it was not raised.")
|
|
||||||
except virt_inspector.InstanceNotFoundException:
|
|
||||||
# exception has been raised as expected.
|
|
||||||
_, _, trace = sys.exc_info()
|
|
||||||
while trace.tb_next:
|
|
||||||
# iterate until the original exception source, bar.
|
|
||||||
trace = trace.tb_next
|
|
||||||
|
|
||||||
# original frame will contain the 'foo' variable.
|
|
||||||
self.assertEqual('foofoo', trace.tb_frame.f_locals['foo'])
|
|
||||||
|
|
||||||
@mock.patch.object(hyperv_inspector, 'utilsfactory')
|
|
||||||
def test_compute_host_max_cpu_clock(self, mock_utilsfactory):
|
|
||||||
mock_cpu = {'MaxClockSpeed': 1000}
|
|
||||||
hostutils = mock_utilsfactory.get_hostutils.return_value.get_cpus_info
|
|
||||||
hostutils.return_value = [mock_cpu, mock_cpu]
|
|
||||||
|
|
||||||
cpu_clock = self._inspector._compute_host_max_cpu_clock()
|
|
||||||
self.assertEqual(2000.0, cpu_clock)
|
|
||||||
|
|
||||||
def test_inspect_instance(self):
|
|
||||||
fake_instance_name = 'fake_instance_name'
|
|
||||||
fake_cpu_clock_used = 2000
|
|
||||||
fake_cpu_count = 3000
|
|
||||||
fake_uptime = 4000
|
|
||||||
|
|
||||||
self._inspector._host_max_cpu_clock = 4000.0
|
|
||||||
fake_cpu_percent_used = (fake_cpu_clock_used /
|
|
||||||
self._inspector._host_max_cpu_clock)
|
|
||||||
fake_cpu_time = (int(fake_uptime * fake_cpu_percent_used) *
|
|
||||||
1000)
|
|
||||||
self._inspector._utils.get_cpu_metrics.return_value = (
|
|
||||||
fake_cpu_clock_used, fake_cpu_count, fake_uptime)
|
|
||||||
fake_usage = self._inspector._utils.get_memory_metrics.return_value
|
|
||||||
|
|
||||||
stats = self._inspector.inspect_instance(fake_instance_name, None)
|
|
||||||
|
|
||||||
self.assertEqual(fake_cpu_count, stats.cpu_number)
|
|
||||||
self.assertEqual(fake_cpu_time, stats.cpu_time)
|
|
||||||
self.assertEqual(fake_usage, stats.memory_usage)
|
|
||||||
|
|
||||||
def test_inspect_vnics(self):
|
|
||||||
fake_instance_name = 'fake_instance_name'
|
|
||||||
fake_rx_mb = 1000
|
|
||||||
fake_tx_mb = 2000
|
|
||||||
fake_element_name = 'fake_element_name'
|
|
||||||
fake_address = 'fake_address'
|
|
||||||
|
|
||||||
self._inspector._utils.get_vnic_metrics.return_value = [{
|
|
||||||
'rx_mb': fake_rx_mb,
|
|
||||||
'tx_mb': fake_tx_mb,
|
|
||||||
'element_name': fake_element_name,
|
|
||||||
'address': fake_address}]
|
|
||||||
|
|
||||||
inspected_vnics = list(self._inspector.inspect_vnics(
|
|
||||||
fake_instance_name, None))
|
|
||||||
|
|
||||||
self.assertEqual(1, len(inspected_vnics))
|
|
||||||
|
|
||||||
inspected_stats = inspected_vnics[0]
|
|
||||||
self.assertEqual(fake_element_name, inspected_stats.name)
|
|
||||||
self.assertEqual(fake_address, inspected_stats.mac)
|
|
||||||
self.assertEqual(fake_rx_mb * units.Mi, inspected_stats.rx_bytes)
|
|
||||||
self.assertEqual(fake_tx_mb * units.Mi, inspected_stats.tx_bytes)
|
|
||||||
|
|
||||||
def test_inspect_disks(self):
|
|
||||||
fake_instance_name = 'fake_instance_name'
|
|
||||||
fake_read_mb = 1000
|
|
||||||
fake_write_mb = 2000
|
|
||||||
fake_instance_id = "fake_fake_instance_id"
|
|
||||||
fake_host_resource = "fake_host_resource"
|
|
||||||
|
|
||||||
self._inspector._utils.get_disk_metrics.return_value = [{
|
|
||||||
'read_mb': fake_read_mb,
|
|
||||||
'write_mb': fake_write_mb,
|
|
||||||
'instance_id': fake_instance_id,
|
|
||||||
'host_resource': fake_host_resource}]
|
|
||||||
|
|
||||||
inspected_disks = list(self._inspector.inspect_disks(
|
|
||||||
fake_instance_name, None))
|
|
||||||
|
|
||||||
self.assertEqual(1, len(inspected_disks))
|
|
||||||
|
|
||||||
inspected_stats = inspected_disks[0]
|
|
||||||
self.assertEqual(fake_instance_id, inspected_stats.device)
|
|
||||||
self.assertEqual(fake_read_mb * units.Mi, inspected_stats.read_bytes)
|
|
||||||
self.assertEqual(fake_write_mb * units.Mi, inspected_stats.write_bytes)
|
|
||||||
|
|
||||||
def test_inspect_disk_latency(self):
|
|
||||||
fake_instance_name = mock.sentinel.INSTANCE_NAME
|
|
||||||
fake_disk_latency = 1000
|
|
||||||
fake_instance_id = mock.sentinel.INSTANCE_ID
|
|
||||||
|
|
||||||
self._inspector._utils.get_disk_latency_metrics.return_value = [{
|
|
||||||
'disk_latency': fake_disk_latency,
|
|
||||||
'instance_id': fake_instance_id}]
|
|
||||||
|
|
||||||
inspected_disks = list(self._inspector.inspect_disk_latency(
|
|
||||||
fake_instance_name, None))
|
|
||||||
|
|
||||||
self.assertEqual(1, len(inspected_disks))
|
|
||||||
|
|
||||||
inspected_stats = inspected_disks[0]
|
|
||||||
self.assertEqual(fake_instance_id, inspected_stats.device)
|
|
||||||
self.assertEqual(1, inspected_stats.disk_latency)
|
|
||||||
|
|
||||||
def test_inspect_disk_iops_count(self):
|
|
||||||
fake_instance_name = mock.sentinel.INSTANCE_NAME
|
|
||||||
fake_disk_iops_count = 53
|
|
||||||
fake_instance_id = mock.sentinel.INSTANCE_ID
|
|
||||||
|
|
||||||
self._inspector._utils.get_disk_iops_count.return_value = [{
|
|
||||||
'iops_count': fake_disk_iops_count,
|
|
||||||
'instance_id': fake_instance_id}]
|
|
||||||
|
|
||||||
inspected_disks = list(self._inspector.inspect_disk_iops(
|
|
||||||
fake_instance_name, None))
|
|
||||||
|
|
||||||
self.assertEqual(1, len(inspected_disks))
|
|
||||||
|
|
||||||
inspected_stats = inspected_disks[0]
|
|
||||||
self.assertEqual(fake_instance_id, inspected_stats.device)
|
|
||||||
self.assertEqual(53, inspected_stats.iops_count)
|
|
@ -85,13 +85,13 @@ The following meters are collected for OpenStack Compute.
|
|||||||
+===========+=======+======+==========+==========+=========+==================+
|
+===========+=======+======+==========+==========+=========+==================+
|
||||||
| **Meters added in the Mitaka release or earlier** |
|
| **Meters added in the Mitaka release or earlier** |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| memory | Gauge | MB | instance | Notific\ | Libvirt,| Volume of RAM |
|
| memory | Gauge | MB | instance | Notific\ | Libvirt | Volume of RAM |
|
||||||
| | | | ID | ation | Hyper-V | allocated to the |
|
| | | | ID | ation | | allocated to the |
|
||||||
| | | | | | | instance |
|
| | | | | | | instance |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| memory.\ | Gauge | MB | instance | Pollster | Libvirt,| Volume of RAM |
|
| memory.\ | Gauge | MB | instance | Pollster | Libvirt,| Volume of RAM |
|
||||||
| usage | | | ID | | Hyper-V,| used by the inst\|
|
| usage | | | ID | | vSphere,| used by the inst\|
|
||||||
| | | | | | vSphere,| ance from the |
|
| | | | | | | ance from the |
|
||||||
| | | | | | | amount of its |
|
| | | | | | | amount of its |
|
||||||
| | | | | | | allocated memory |
|
| | | | | | | allocated memory |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
@ -100,41 +100,34 @@ The following meters are collected for OpenStack Compute.
|
|||||||
| | | | | | | ance on the phy\ |
|
| | | | | | | ance on the phy\ |
|
||||||
| | | | | | | sical machine |
|
| | | | | | | sical machine |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| cpu | Cumu\ | ns | instance | Pollster | Libvirt,| CPU time used |
|
| cpu | Cumu\ | ns | instance | Pollster | Libvirt | CPU time used |
|
||||||
| | lative| | ID | | Hyper-V | |
|
| | lative| | ID | | | |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| vcpus | Gauge | vcpu | instance | Notific\ | Libvirt,| Number of virtual|
|
| vcpus | Gauge | vcpu | instance | Notific\ | Libvirt | Number of virtual|
|
||||||
| | | | ID | ation | Hyper-V | CPUs allocated to|
|
| | | | ID | ation | | CPUs allocated to|
|
||||||
| | | | | | | the instance |
|
| | | | | | | the instance |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| disk.dev\ | Cumu\ | req\ | disk ID | Pollster | Libvirt,| Number of read |
|
| disk.dev\ | Cumu\ | req\ | disk ID | Pollster | Libvirt | Number of read |
|
||||||
| ice.read\ | lative| uest | | | Hyper-V | requests |
|
| ice.read\ | lative| uest | | | | requests |
|
||||||
| .requests | | | | | | |
|
| .requests | | | | | | |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| disk.dev\ | Cumu\ | req\ | disk ID | Pollster | Libvirt,| Number of write |
|
| disk.dev\ | Cumu\ | req\ | disk ID | Pollster | Libvirt | Number of write |
|
||||||
| ice.write\| lative| uest | | | Hyper-V | requests |
|
| ice.write\| lative| uest | | | | requests |
|
||||||
| .requests | | | | | | |
|
| .requests | | | | | | |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| disk.dev\ | Cumu\ | B | disk ID | Pollster | Libvirt,| Volume of reads |
|
| disk.dev\ | Cumu\ | B | disk ID | Pollster | Libvirt | Volume of reads |
|
||||||
| ice.read\ | lative| | | | Hyper-V | |
|
| ice.read\ | lative| | | | | |
|
||||||
| .bytes | | | | | | |
|
| .bytes | | | | | | |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| disk.dev\ | Cumu\ | B | disk ID | Pollster | Libvirt,| Volume of writes |
|
| disk.dev\ | Cumu\ | B | disk ID | Pollster | Libvirt | Volume of writes |
|
||||||
| ice.write\| lative| | | | Hyper-V | |
|
| ice.write\| lative| | | | | |
|
||||||
| .bytes | | | | | | |
|
| .bytes | | | | | | |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| disk.root\| Gauge | GB | instance | Notific\ | Libvirt,| Size of root disk|
|
| disk.root\| Gauge | GB | instance | Notific\ | Libvirt | Size of root disk|
|
||||||
| .size | | | ID | ation | Hyper-V | |
|
| .size | | | ID | ation | | |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| disk.ephe\| Gauge | GB | instance | Notific\ | Libvirt,| Size of ephemeral|
|
| disk.ephe\| Gauge | GB | instance | Notific\ | Libvirt | Size of ephemeral|
|
||||||
| meral.size| | | ID | ation | Hyper-V | disk |
|
| meral.size| | | ID | ation | | disk |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
|
||||||
| disk.dev\ | Gauge | ms | disk ID | Pollster | Hyper-V | Average disk la\ |
|
|
||||||
| ice.late\ | | | | | | tency per device |
|
|
||||||
| ncy | | | | | | |
|
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
|
||||||
| disk.dev\ | Gauge | coun\| disk ID | Pollster | Hyper-V | Average disk io\ |
|
|
||||||
| ice.iops | | t/s | | | | ps per device |
|
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| disk.dev\ | Gauge | B | disk ID | Pollster | Libvirt | The amount of d\ |
|
| disk.dev\ | Gauge | B | disk ID | Pollster | Libvirt | The amount of d\ |
|
||||||
| ice.capa\ | | | | | | isk per device |
|
| ice.capa\ | | | | | | isk per device |
|
||||||
@ -153,20 +146,20 @@ The following meters are collected for OpenStack Compute.
|
|||||||
| | | | | | | iner on the hos\ |
|
| | | | | | | iner on the hos\ |
|
||||||
| | | | | | | t per device |
|
| | | | | | | t per device |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| network.\ | Cumu\ | B | interface| Pollster | Libvirt,| Number of |
|
| network.\ | Cumu\ | B | interface| Pollster | Libvirt | Number of |
|
||||||
| incoming.\| lative| | ID | | Hyper-V | incoming bytes |
|
| incoming.\| lative| | ID | | | incoming bytes |
|
||||||
| bytes | | | | | | |
|
| bytes | | | | | | |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| network.\ | Cumu\ | B | interface| Pollster | Libvirt,| Number of |
|
| network.\ | Cumu\ | B | interface| Pollster | Libvirt | Number of |
|
||||||
| outgoing\ | lative| | ID | | Hyper-V | outgoing bytes |
|
| outgoing\ | lative| | ID | | | outgoing bytes |
|
||||||
| .bytes | | | | | | |
|
| .bytes | | | | | | |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| network.\ | Cumu\ | pac\ | interface| Pollster | Libvirt,| Number of |
|
| network.\ | Cumu\ | pac\ | interface| Pollster | Libvirt | Number of |
|
||||||
| incoming\ | lative| ket | ID | | Hyper-V | incoming packets |
|
| incoming\ | lative| ket | ID | | | incoming packets |
|
||||||
| .packets | | | | | | |
|
| .packets | | | | | | |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| network.\ | Cumu\ | pac\ | interface| Pollster | Libvirt,| Number of |
|
| network.\ | Cumu\ | pac\ | interface| Pollster | Libvirt | Number of |
|
||||||
| outgoing\ | lative| ket | ID | | Hyper-V | outgoing packets |
|
| outgoing\ | lative| ket | ID | | | outgoing packets |
|
||||||
| .packets | | | | | | |
|
| .packets | | | | | | |
|
||||||
+-----------+-------+------+----------+----------+---------+------------------+
|
+-----------+-------+------+----------+----------+---------+------------------+
|
||||||
| **Meters added in the Newton release** |
|
| **Meters added in the Newton release** |
|
||||||
|
@ -78,8 +78,6 @@ compute hosts.
|
|||||||
The following is a list of supported hypervisors.
|
The following is a list of supported hypervisors.
|
||||||
|
|
||||||
- `Libvirt supported hypervisors <http://libvirt.org/>`__ such as KVM and QEMU
|
- `Libvirt supported hypervisors <http://libvirt.org/>`__ such as KVM and QEMU
|
||||||
- `Hyper-V <https://docs.microsoft.com/en-us/windows-server/virtualization/hyper-v/hyper-v-on-windows-server>`__
|
|
||||||
- `XEN <http://www.xenproject.org/help/documentation.html>`__
|
|
||||||
- `VMware vSphere <https://www.vmware.com/support/vsphere-hypervisor.html>`__
|
- `VMware vSphere <https://www.vmware.com/support/vsphere-hypervisor.html>`__
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
upgrade:
|
||||||
|
- |
|
||||||
|
Support for running ceilometer in Windows operating systems has been
|
||||||
|
removed. Because of the removal, Hyper-V inspector has also been removed.
|
@ -73,8 +73,6 @@ ceilometer.poll.compute =
|
|||||||
disk.device.write.bytes = ceilometer.compute.pollsters.disk:PerDeviceWriteBytesPollster
|
disk.device.write.bytes = ceilometer.compute.pollsters.disk:PerDeviceWriteBytesPollster
|
||||||
disk.device.read.latency = ceilometer.compute.pollsters.disk:PerDeviceDiskReadLatencyPollster
|
disk.device.read.latency = ceilometer.compute.pollsters.disk:PerDeviceDiskReadLatencyPollster
|
||||||
disk.device.write.latency = ceilometer.compute.pollsters.disk:PerDeviceDiskWriteLatencyPollster
|
disk.device.write.latency = ceilometer.compute.pollsters.disk:PerDeviceDiskWriteLatencyPollster
|
||||||
disk.device.latency = ceilometer.compute.pollsters.disk:PerDeviceDiskLatencyPollster
|
|
||||||
disk.device.iops = ceilometer.compute.pollsters.disk:PerDeviceDiskIOPSPollster
|
|
||||||
cpu = ceilometer.compute.pollsters.instance_stats:CPUPollster
|
cpu = ceilometer.compute.pollsters.instance_stats:CPUPollster
|
||||||
cpu_util = ceilometer.compute.pollsters.instance_stats:CPUUtilPollster
|
cpu_util = ceilometer.compute.pollsters.instance_stats:CPUUtilPollster
|
||||||
cpu_l3_cache = ceilometer.compute.pollsters.instance_stats:CPUL3CachePollster
|
cpu_l3_cache = ceilometer.compute.pollsters.instance_stats:CPUL3CachePollster
|
||||||
@ -176,7 +174,6 @@ ceilometer.poll.central =
|
|||||||
|
|
||||||
ceilometer.compute.virt =
|
ceilometer.compute.virt =
|
||||||
libvirt = ceilometer.compute.virt.libvirt.inspector:LibvirtInspector
|
libvirt = ceilometer.compute.virt.libvirt.inspector:LibvirtInspector
|
||||||
hyperv = ceilometer.compute.virt.hyperv.inspector:HyperVInspector
|
|
||||||
vsphere = ceilometer.compute.virt.vmware.inspector:VsphereInspector
|
vsphere = ceilometer.compute.virt.vmware.inspector:VsphereInspector
|
||||||
|
|
||||||
ceilometer.sample.publisher =
|
ceilometer.sample.publisher =
|
||||||
|
@ -5,7 +5,6 @@
|
|||||||
coverage!=4.4,>=4.0 # Apache-2.0
|
coverage!=4.4,>=4.0 # Apache-2.0
|
||||||
eventlet>=0.30.1 # MIT
|
eventlet>=0.30.1 # MIT
|
||||||
fixtures>=3.0.0 # Apache-2.0/BSD
|
fixtures>=3.0.0 # Apache-2.0/BSD
|
||||||
os-win>=3.0.0 # Apache-2.0
|
|
||||||
oslo.messaging[kafka]>=8.0.0 # Apache-2.0
|
oslo.messaging[kafka]>=8.0.0 # Apache-2.0
|
||||||
oslotest>=3.8.0 # Apache-2.0
|
oslotest>=3.8.0 # Apache-2.0
|
||||||
oslo.vmware>=2.17.0 # Apache-2.0
|
oslo.vmware>=2.17.0 # Apache-2.0
|
||||||
|
Loading…
x
Reference in New Issue
Block a user