Merge 3.5 (issue #27456)
This commit is contained in:
commit
503ba3ed97
|
@ -39,6 +39,17 @@ def _test_selector_event(selector, fd, event):
|
|||
return bool(key.events & event)
|
||||
|
||||
|
||||
if hasattr(socket, 'TCP_NODELAY'):
|
||||
def _set_nodelay(sock):
|
||||
if (sock.family in {socket.AF_INET, socket.AF_INET6} and
|
||||
sock.type == socket.SOCK_STREAM and
|
||||
sock.proto == socket.IPPROTO_TCP):
|
||||
sock.setsockopt(socket.IPPROTO_TCP, socket.TCP_NODELAY, 1)
|
||||
else:
|
||||
def _set_nodelay(sock):
|
||||
pass
|
||||
|
||||
|
||||
class BaseSelectorEventLoop(base_events.BaseEventLoop):
|
||||
"""Selector event loop.
|
||||
|
||||
|
@ -641,6 +652,11 @@ class _SelectorSocketTransport(_SelectorTransport):
|
|||
self._eof = False
|
||||
self._paused = False
|
||||
|
||||
# Disable the Nagle algorithm -- small writes will be
|
||||
# sent without waiting for the TCP ACK. This generally
|
||||
# decreases the latency (in some cases significantly.)
|
||||
_set_nodelay(self._sock)
|
||||
|
||||
self._loop.call_soon(self._protocol.connection_made, self)
|
||||
# only start reading when connection_made() has been called
|
||||
self._loop.call_soon(self._loop.add_reader,
|
||||
|
|
Loading…
Reference in New Issue