[metrics-bugs] #33420 [Metrics/Onionperf]: Add CBT events to Onionperf result files

Tor Bug Tracker & Wiki blackhole at torproject.org
Thu Jun 11 14:34:26 UTC 2020


#33420: Add CBT events to Onionperf result files
-------------------------------------------------+-------------------------
 Reporter:  acute                                |          Owner:
                                                 |  metrics-team
     Type:  enhancement                          |         Status:
                                                 |  assigned
 Priority:  Medium                               |      Milestone:
Component:  Metrics/Onionperf                    |        Version:
 Severity:  Normal                               |     Resolution:
 Keywords:  metrics-team-roadmap-2020, metrics-  |  Actual Points:  0.3
  team-roadmap-2020-june                         |
Parent ID:  #33321                               |         Points:  2.0
 Reviewer:                                       |        Sponsor:
                                                 |  Sponsor59-must
-------------------------------------------------+-------------------------
Changes (by karsten):

 * owner:  karsten => metrics-team
 * status:  needs_information => assigned


Comment:

 I briefly ran mikeperry's patch and want to share my experience here.

 I had to patch the branch by calling the relevant functions as part of
 dropping guards. The only reason was that Stem (obviously) doesn't have a
 `drop_timeouts()` function yet. Here's my patch on top of mikeperry's
 branch:

 {{{
 diff --git a/src/feature/control/control_cmd.c
 b/src/feature/control/control_cmd.c
 index 74d542ec6d..3cd586ccff 100644
 --- a/src/feature/control/control_cmd.c
 +++ b/src/feature/control/control_cmd.c
 @@ -1393,8 +1393,12 @@ handle_control_dropguards(control_connection_t
 *conn,
    }

    remove_all_entry_guards();
 +  circuit_build_times_reset(get_circuit_build_times_mutable());
    send_control_done(conn);

 +  cbt_control_event_buildtimeout_set(get_circuit_build_times(),
 +                                     BUILDTIMEOUT_SET_EVENT_RESET);
 +
    return 0;
  }

 }}}

 I then patched OnionPerf to:
  - use entry guards (which isn't technically required for this branch, but
 I did this when working on #33399),
  - increase the `NEWNYM` interval from 5 minutes to 1 hour and drop guards
 and timeouts right after sending the `NEWNYM` command (even though this
 could have happened separately with `NEWNYM` being sent every 5 minutes
 and the two drop commands happening once per hour), and
  - distinguish `BUILDTIMEOUT_SET COMPUTED` events from other
 `BUILDTIMEOUT_SET` events.

 Here's my patch:

 {{{
 diff --git a/onionperf/analysis.py b/onionperf/analysis.py
 index 20ca354..7913adc 100644
 --- a/onionperf/analysis.py
 +++ b/onionperf/analysis.py
 @@ -12,7 +12,7 @@ from socket import gethostname
  from abc import ABCMeta, abstractmethod

  # stem imports
 -from stem import CircEvent, CircStatus, CircPurpose, StreamStatus
 +from stem import CircEvent, CircStatus, CircPurpose, StreamStatus,
 TimeoutSetType
  from stem.response.events import CircuitEvent, CircMinorEvent,
 StreamEvent, BandwidthEvent, BuildTimeoutSetEvent
  from stem.response import ControlMessage, convert

 @@ -630,8 +630,12 @@ class TorCtlParser(Parser):
          self.bandwidth_summary['bytes_written'][int(arrival_dt)] =
 event.written

      def __handle_buildtimeout(self, event, arrival_dt):
 -        self.build_timeout_last = event.timeout
 -        self.build_quantile_last = event.quantile
 +        if event.set_type == TimeoutSetType.COMPUTED:
 +            self.build_timeout_last = event.timeout
 +            self.build_quantile_last = event.quantile
 +        else:
 +            self.build_timeout_last = None
 +            self.build_quantile_last = None

      def __handle_event(self, event, arrival_dt):
          if isinstance(event, (CircuitEvent, CircMinorEvent)):
 diff --git a/onionperf/measurement.py b/onionperf/measurement.py
 index 4a58bc4..c8fc9f8 100644
 --- a/onionperf/measurement.py
 +++ b/onionperf/measurement.py
 @@ -388,8 +388,8 @@ WarnUnsafeSocks 0\nSafeLogging 0\nMaxCircuitDirtiness
 60 seconds\nDataDirectory
                  tor_config = tor_config + f.read()
          if name == "client" and self.additional_client_conf:
              tor_config += self.additional_client_conf
 -        if not 'UseEntryGuards' in tor_config and not 'UseBridges' in
 tor_config:
 -            tor_config += "UseEntryGuards 0\n"
 +        #if not 'UseEntryGuards' in tor_config and not 'UseBridges' in
 tor_config:
 +            #tor_config += "UseEntryGuards 0\n"
          if name == "server" and self.single_onion:
              tor_config += "HiddenServiceSingleHopMode
 1\nHiddenServiceNonAnonymousMode 1\n"
          return tor_config
 @@ -466,7 +466,7 @@ WarnUnsafeSocks 0\nSafeLogging 0\nMaxCircuitDirtiness
 60 seconds\nDataDirectory
          time.sleep(3)

          torctl_events = [e for e in monitor.get_supported_torctl_events()
 if e not in ['DEBUG', 'INFO', 'NOTICE', 'WARN', 'ERR']]
 -        newnym_interval_seconds = 300
 +        newnym_interval_seconds = 3600
          torctl_args = (control_port, torctl_writable, torctl_events,
 newnym_interval_seconds, self.done_event)
          torctl_helper = threading.Thread(target=monitor.tor_monitor_run,
 name="torctl_{0}_helper".format(name), args=torctl_args)
          torctl_helper.start()
 diff --git a/onionperf/monitor.py b/onionperf/monitor.py
 index 5387bff..074876e 100644
 --- a/onionperf/monitor.py
 +++ b/onionperf/monitor.py
 @@ -64,6 +64,7 @@ class TorMonitor(object):
                      if newnym_interval_seconds is not None and
 interval_count >= newnym_interval_seconds:
                          interval_count = 0
                          torctl.signal(Signal.NEWNYM)
 +                        torctl.drop_guards()
              except KeyboardInterrupt:
                  pass  # the user hit ctrl+c

 }}}

 I'm attaching the OnionPerf analysis file from running this branch for a
 couple hours. When you grep for `"build"`, you'll find that there
 alternating batches of circuits having `"build_quantile"` and
 `"build_timeout"` fields followed by batches of circuits without these two
 fields. In the latter case there was no build timeout set.

 Reassigning to metrics-team, so that others can look into mikeperry's
 patch and also think about remaining steps here. This ticket is far from
 being done.

--
Ticket URL: <https://trac.torproject.org/projects/tor/ticket/33420#comment:12>
Tor Bug Tracker & Wiki <https://trac.torproject.org/>
The Tor Project: anonymity online


More information about the metrics-bugs mailing list