Fix calculating of duration in simulator.py
When we calculate metrics like msg/sec, latency, etc we expect the start and end time as time of the first and last processed message: RPC Server life timeline: [----0..5 sec----][---5..10 sec---][---10..15 sec--] waiting clients 10 msg recved wait sigint expected: duration 5 sec, 2 msg/sec actual (incorrect): duration 15 sec, 0.6 msg/sec no reason to set the boundaries if server was idle few seconds before running of clients and after. Change-Id: I33e0a605b54ea7b89977504892528c41c3b00a68
This commit is contained in:
parent
ee8fff03d9
commit
6a41a81c9e
@ -125,6 +125,9 @@ class MessageStatsCollector(object):
|
|||||||
def monitor(self):
|
def monitor(self):
|
||||||
global IS_RUNNING
|
global IS_RUNNING
|
||||||
if IS_RUNNING:
|
if IS_RUNNING:
|
||||||
|
# NOTE(kbespalov): this way not properly works
|
||||||
|
# because the monitor starting with range 1sec +-150 ms
|
||||||
|
# due to high threading contention between rpc clients
|
||||||
threading.Timer(1.0, self.monitor).start()
|
threading.Timer(1.0, self.monitor).start()
|
||||||
now = time.time()
|
now = time.time()
|
||||||
|
|
||||||
@ -187,6 +190,12 @@ class MessageStatsCollector(object):
|
|||||||
for point in itertools.chain(*(c.get_series() for c in collectors)):
|
for point in itertools.chain(*(c.get_series() for c in collectors)):
|
||||||
count += point['count']
|
count += point['count']
|
||||||
size += point['size']
|
size += point['size']
|
||||||
|
if point['count']:
|
||||||
|
# NOTE(kbespalov):
|
||||||
|
# we except the start and end time as time of
|
||||||
|
# first and last processed message, no reason
|
||||||
|
# to set boundaries if server was idle before
|
||||||
|
# running of clients and after.
|
||||||
start = min(start, point['timestamp'])
|
start = min(start, point['timestamp'])
|
||||||
end = max(end, point['timestamp'])
|
end = max(end, point['timestamp'])
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user