record tor-launch time in DebugTiming
This commit is contained in:
parent
01ed9902de
commit
12c4c51fd8
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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):
|
||||||
|
|
Loading…
Reference in New Issue
Block a user