diff options
author | Richard van der Hoff <github@rvanderhoff.org.uk> | 2018-01-23 19:39:26 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-01-23 19:39:26 +0000 |
commit | 25e2456ee7ee7f53d5452db4a38d0c4cccc53fd8 (patch) | |
tree | e2e81cb20b566f0ecc1eb2ef5e406073b9850f73 /synapse/metrics/__init__.py | |
parent | add ?ts massaging for ASes (#2754) (diff) | |
parent | Add some comments about the reactor tick time metric (diff) | |
download | synapse-25e2456ee7ee7f53d5452db4a38d0c4cccc53fd8.tar.xz |
Merge pull request #2816 from matrix-org/rav/metrics_comments
Add some comments about the reactor tick time metric
Diffstat (limited to 'synapse/metrics/__init__.py')
-rw-r--r-- | synapse/metrics/__init__.py | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/synapse/metrics/__init__.py b/synapse/metrics/__init__.py index 2265e6e8d6..e0cfb7d08f 100644 --- a/synapse/metrics/__init__.py +++ b/synapse/metrics/__init__.py @@ -146,10 +146,15 @@ def runUntilCurrentTimer(func): num_pending += 1 num_pending += len(reactor.threadCallQueue) - start = time.time() * 1000 ret = func(*args, **kwargs) end = time.time() * 1000 + + # record the amount of wallclock time spent running pending calls. + # This is a proxy for the actual amount of time between reactor polls, + # since about 25% of time is actually spent running things triggered by + # I/O events, but that is harder to capture without rewriting half the + # reactor. tick_time.inc_by(end - start) pending_calls_metric.inc_by(num_pending) |