Remove meter hardware.network.bandwidth.bytes

The metering is just the speed of nic, if the nic is Gigabit-NIC,
the value will always be Gigabit:) and it is better to shown in
the metadata.

Change-Id: Iaf95f4e9a0ff0a36fe1e8d03d5c87bf5b24bd24b
Closes-Bug: #1331001
This commit is contained in:
liuqing 2014-06-17 23:15:01 +08:00
parent 7b2bea56f3
commit 009053061a
8 changed files with 30 additions and 48 deletions

View File

@ -59,20 +59,19 @@ DiskStats = collections.namedtuple('DiskStats', ['size', 'used'])
# name: the name of the interface
# mac: the MAC of the interface
# ip: the IP of the interface
# speed: the speed of the interface (bytes/s)
#
Interface = collections.namedtuple('Interface', ['name', 'mac', 'ip'])
Interface = collections.namedtuple('Interface', ['name', 'mac', 'ip', 'speed'])
# Named tuple representing network interface statistics.
#
# bandwidth: current bandwidth (bytes/s)
# rx_bytes: total number of octets received (bytes)
# tx_bytes: total number of octets transmitted (bytes)
# error: number of outbound packets not transmitted because of errors
#
InterfaceStats = collections.namedtuple(
'InterfaceStats',
['bandwidth', 'rx_bytes', 'tx_bytes', 'error'])
InterfaceStats = collections.namedtuple('InterfaceStats',
['rx_bytes', 'tx_bytes', 'error'])
@six.add_metaclass(abc.ABCMeta)

View File

@ -67,7 +67,7 @@ class SNMPInspector(base.Inspector):
#Network Interface OIDs
_interface_index_oid = "1.3.6.1.2.1.2.2.1.1"
_interface_name_oid = "1.3.6.1.2.1.2.2.1.2"
_interface_bandwidth_oid = "1.3.6.1.2.1.2.2.1.5"
_interface_speed_oid = "1.3.6.1.2.1.2.2.1.5"
_interface_mac_oid = "1.3.6.1.2.1.2.2.1.6"
_interface_ip_oid = "1.3.6.1.2.1.4.20.1.2"
_interface_received_oid = "1.3.6.1.2.1.2.2.1.10"
@ -162,10 +162,10 @@ class SNMPInspector(base.Inspector):
mac_oid = "%s.%s" % (self._interface_mac_oid,
str(value))
mac = self._get_value_from_oid(mac_oid, host)
bw_oid = "%s.%s" % (self._interface_bandwidth_oid,
speed_oid = "%s.%s" % (self._interface_speed_oid,
str(value))
# bits/s to byte/s
bandwidth = self._get_value_from_oid(bw_oid, host) / 8
speed = self._get_value_from_oid(speed_oid, host) / 8
rx_oid = "%s.%s" % (self._interface_received_oid,
str(value))
rx_bytes = self._get_value_from_oid(rx_oid, host)
@ -179,9 +179,9 @@ class SNMPInspector(base.Inspector):
adapted_mac = mac.prettyPrint().replace('0x', '')
interface = base.Interface(name=str(name),
mac=adapted_mac,
ip=str(ip))
stats = base.InterfaceStats(bandwidth=int(bandwidth),
rx_bytes=int(rx_bytes),
ip=str(ip),
speed=int(speed))
stats = base.InterfaceStats(rx_bytes=int(rx_bytes),
tx_bytes=int(tx_bytes),
error=int(error))
yield (interface, stats)

View File

@ -29,20 +29,6 @@ class _Base(plugin.HardwarePollster):
INSPECT_METHOD = 'inspect_network'
class BandwidthBytesPollster(_Base):
@staticmethod
def generate_one_sample(host, c_data):
(nic, info) = c_data
return util.make_sample_from_host(host,
name='network.bandwidth.bytes',
type=sample.TYPE_GAUGE,
unit='B',
volume=info.bandwidth,
res_metadata=nic,
)
class IncomingBytesPollster(_Base):
@staticmethod

View File

@ -30,9 +30,9 @@ class InspectorBaseTest(object):
network = [(base.Interface(name='eth0',
mac='112233445566',
ip='10.0.0.1'),
base.InterfaceStats(bandwidth=1250000 / 8,
rx_bytes=1000,
ip='10.0.0.1',
speed=1250000 / 8),
base.InterfaceStats(rx_bytes=1000,
tx_bytes=2000,
error=1)),
]

View File

@ -140,11 +140,11 @@ GETCMD_MAP = {
FakeMac(),
)],
),
ins._interface_bandwidth_oid + '.1': (None,
ins._interface_speed_oid + '.1': (None,
None,
0,
[('',
Base.network[0][1].bandwidth * 8,
Base.network[0][0].speed * 8,
)],
),
ins._interface_received_oid + '.1': (None,

View File

@ -32,9 +32,9 @@ class FakeInspector(inspector_base.Inspector):
MEMORY = inspector_base.MemoryStats(total=1000, used=90)
NET = (inspector_base.Interface(name='test.teest',
mac='001122334455',
ip='10.0.0.2'),
inspector_base.InterfaceStats(bandwidth=1000,
rx_bytes=90,
ip='10.0.0.2',
speed=1000),
inspector_base.InterfaceStats(rx_bytes=90,
tx_bytes=80,
error=1))

View File

@ -21,22 +21,20 @@ from ceilometer.tests.hardware.pollsters import base
class TestNetPollsters(base.TestPollsterBase):
def test_bandwidth(self):
self._check_get_samples(net.BandwidthBytesPollster,
'hardware.network.bandwidth.bytes',
1000, sample.TYPE_GAUGE)
def test_incoming(self):
self._check_get_samples(net.IncomingBytesPollster,
'hardware.network.incoming.bytes',
90, sample.TYPE_CUMULATIVE)
90, sample.TYPE_CUMULATIVE,
expected_unit='B')
def test_outgoing(self):
self._check_get_samples(net.OutgoingBytesPollster,
'hardware.network.outgoing.bytes',
80, sample.TYPE_CUMULATIVE)
80, sample.TYPE_CUMULATIVE,
expected_unit='B')
def test_error(self):
self._check_get_samples(net.OutgoingErrorsPollster,
'hardware.network.outgoing.errors',
1, sample.TYPE_CUMULATIVE)
1, sample.TYPE_CUMULATIVE,
expected_unit='packet')

View File

@ -129,7 +129,6 @@ ceilometer.poll.central =
hardware.cpu.load.15min = ceilometer.hardware.pollsters.cpu:CPULoad15MinPollster
hardware.disk.size.total = ceilometer.hardware.pollsters.disk:DiskTotalPollster
hardware.disk.size.used = ceilometer.hardware.pollsters.disk:DiskUsedPollster
hardware.network.bandwidth.bytes = ceilometer.hardware.pollsters.net:BandwidthBytesPollster
hardware.network.incoming.bytes = ceilometer.hardware.pollsters.net:IncomingBytesPollster
hardware.network.outgoing.bytes = ceilometer.hardware.pollsters.net:OutgoingBytesPollster
hardware.network.outgoing.errors = ceilometer.hardware.pollsters.net:OutgoingErrorsPollster