[metrics-bugs] #30798 [Metrics/Onionperf]: Develop and deploy tgen model resembling ping
Tor Bug Tracker & Wiki
blackhole at torproject.org
Fri Jun 7 10:29:52 UTC 2019
#30798: Develop and deploy tgen model resembling ping
-------------------------------+------------------------------
Reporter: karsten | Owner: metrics-team
Type: enhancement | Status: new
Priority: High | Milestone:
Component: Metrics/Onionperf | Version:
Severity: Normal | Resolution:
Keywords: | Actual Points:
Parent ID: | Points:
Reviewer: | Sponsor:
-------------------------------+------------------------------
Comment (by irl):
This model would be looking at modeling something close to ICMP ping, but
it's quite an approximation. In Internet Engineering, where you're dealing
with packet switched networks, ping can be useful to determine both round
trip times (average, min, max, jitter) and packet loss. In our case we are
dealing with virtual circuits overlaid onto a packet switched network.
This means that we're only going to get round trip times, as if there is
packet loss we will just see the circuit go down and won't be able to
probe further.
We can still do all the round trip time metrics:
* average - how long does it typically take to get a reply?
* min - upper bound for latency when network is unloaded
* max - lower bound for latency when network is loaded
* max minus min - lower bound for maximum load induced queuing delay
* jitter - variation in latency
The second probe does depend on the first probe in a way that is not the
case for ICMP. Being part of the same stream means that various counters
and timers are going to be linked between probes. We should explicitly
acknowledge this, work out what those counters/timers are (somewhere in
the rate limiting code) and decide if we are affected by them or not.
If there is something like Nagle's algorithm going on then we should
ensure that we're getting all the right flushes in and that we're not
ending up batching our requests.
From discussion with Ana this should be relatively easy to implement the
model, and all the data would be captured in the tgen log for analysis.
I'm not sure if it is easier to hack something together, or to use the
existing framework, which could be flexible enough to be modified simply.
If we're getting numbers that look reasonable then this is probably enough
for the upcoming meeting but I'd want to make sure we're not confusing
what these numbers mean. This work may also be useful for scaling in
general to better understand what counters/timers exist. Maybe we can work
with a network team person to understand this.
In the future it may also be interesting to port
[https://www.bufferbloat.net/projects/codel/wiki/RRUL_test_suite/ RRUL] to
a tgen model. That's not a cheap test to run though.
--
Ticket URL: <https://trac.torproject.org/projects/tor/ticket/30798#comment:1>
Tor Bug Tracker & Wiki <https://trac.torproject.org/>
The Tor Project: anonymity online
More information about the metrics-bugs
mailing list