record tor-launch time in DebugTiming

This commit is contained in:
Brian Warner 2016-03-03 14:31:13 -08:00
parent 01ed9902de
commit 12c4c51fd8
3 changed files with 10 additions and 3 deletions

View File

@ -42,7 +42,7 @@ class TwistedReceiver(BlockingReceiver):
tor_manager = None tor_manager = None
if self.args.tor: if self.args.tor:
from ..twisted.tor_manager import TorManager from ..twisted.tor_manager import TorManager
tor_manager = TorManager(reactor) tor_manager = TorManager(reactor, timing=self.args.timing)
# For now, block everything until Tor has started. Soon: launch # For now, block everything until Tor has started. Soon: launch
# tor in parallel with everything else, make sure the TorManager # tor in parallel with everything else, make sure the TorManager
# can lazy-provide an endpoint, and overlap the startup process # can lazy-provide an endpoint, and overlap the startup process

View File

@ -45,7 +45,7 @@ def send_twisted(args):
tor_manager = None tor_manager = None
if args.tor: if args.tor:
from ..twisted.tor_manager import TorManager from ..twisted.tor_manager import TorManager
tor_manager = TorManager(reactor) tor_manager = TorManager(reactor, timing=args.timing)
# For now, block everything until Tor has started. Soon: launch tor # For now, block everything until Tor has started. Soon: launch tor
# in parallel with everything else, make sure the TorManager can # in parallel with everything else, make sure the TorManager can
# lazy-provide an endpoint, and overlap the startup process with the # lazy-provide an endpoint, and overlap the startup process with the

View File

@ -8,6 +8,7 @@ from twisted.internet.error import ConnectError
from twisted.web import iweb from twisted.web import iweb
import txtorcon import txtorcon
import ipaddr import ipaddr
from ..timing import DebugTiming
from .transit import allocate_tcp_port from .transit import allocate_tcp_port
# based on twisted.web.client._StandardEndpointFactory # based on twisted.web.client._StandardEndpointFactory
@ -39,7 +40,8 @@ class TorWebAgentEndpointFactory(object):
raise web_error.SchemeNotSupported("Unsupported scheme: %r" % (uri.scheme,)) raise web_error.SchemeNotSupported("Unsupported scheme: %r" % (uri.scheme,))
class TorManager: class TorManager:
def __init__(self, reactor, tor_socks_port=None, tor_control_port=9051): def __init__(self, reactor, tor_socks_port=None, tor_control_port=9051,
timing=None):
""" """
If tor_socks_port= is provided, I will assume that it points to a If tor_socks_port= is provided, I will assume that it points to a
functioning SOCKS server, and will use it for all outbound functioning SOCKS server, and will use it for all outbound
@ -61,6 +63,7 @@ class TorManager:
assert isinstance(tor_control_port, int) assert isinstance(tor_control_port, int)
self._tor_socks_port = tor_socks_port self._tor_socks_port = tor_socks_port
self._tor_control_port = tor_control_port self._tor_control_port = tor_control_port
self._timing = timing or DebugTiming()
@inlineCallbacks @inlineCallbacks
def start(self): def start(self):
@ -73,6 +76,7 @@ class TorManager:
self._can_run_service = False self._can_run_service = False
returnValue(True) returnValue(True)
_start_find = self._timing.add_event("find tor")
# try port 9051, then try /var/run/tor/control . Throws on failure. # try port 9051, then try /var/run/tor/control . Throws on failure.
state = None state = None
try: try:
@ -100,11 +104,13 @@ class TorManager:
yield self._create_my_own_tor() yield self._create_my_own_tor()
# that sets self._tor_socks_port and self._tor_protocol # that sets self._tor_socks_port and self._tor_protocol
self._timing.finish_event(_start_find)
self._can_run_service = True self._can_run_service = True
returnValue(True) returnValue(True)
@inlineCallbacks @inlineCallbacks
def _create_my_own_tor(self): def _create_my_own_tor(self):
_start_launch = self._timing.add_event("launch tor")
start = time.time() start = time.time()
config = self.config = txtorcon.TorConfig() config = self.config = txtorcon.TorConfig()
if 0: if 0:
@ -128,6 +134,7 @@ class TorManager:
self._tor_protocol = tpp.tor_protocol self._tor_protocol = tpp.tor_protocol
print("tp:", self._tor_protocol) print("tp:", self._tor_protocol)
print("elapsed:", time.time() - start) print("elapsed:", time.time() - start)
self._timing.finish_event(_start_launch)
returnValue(True) returnValue(True)
def get_web_agent_endpoint_factory(self): def get_web_agent_endpoint_factory(self):