Kaydet (Commit) 163a1ce3 authored tarafından Joffrey F's avatar Joffrey F

Implement retry logic when the npipe open procedure fails

with ERROR_PIPE_BUSY
Signed-off-by: 's avatarJoffrey F <joffrey@docker.com>
üst c7dabbfa
...@@ -5,9 +5,11 @@ import six ...@@ -5,9 +5,11 @@ import six
import win32file import win32file
import win32pipe import win32pipe
cERROR_PIPE_BUSY = 0xe7
cSECURITY_SQOS_PRESENT = 0x100000 cSECURITY_SQOS_PRESENT = 0x100000
cSECURITY_ANONYMOUS = 0 cSECURITY_ANONYMOUS = 0
cPIPE_READMODE_MESSAGE = 2
RETRY_WAIT_TIMEOUT = 10000
def check_closed(f): def check_closed(f):
...@@ -46,15 +48,27 @@ class NpipeSocket(object): ...@@ -46,15 +48,27 @@ class NpipeSocket(object):
@check_closed @check_closed
def connect(self, address): def connect(self, address):
win32pipe.WaitNamedPipe(address, self._timeout) win32pipe.WaitNamedPipe(address, self._timeout)
handle = win32file.CreateFile( try:
address, handle = win32file.CreateFile(
win32file.GENERIC_READ | win32file.GENERIC_WRITE, address,
0, win32file.GENERIC_READ | win32file.GENERIC_WRITE,
None, 0,
win32file.OPEN_EXISTING, None,
cSECURITY_ANONYMOUS | cSECURITY_SQOS_PRESENT, win32file.OPEN_EXISTING,
0 cSECURITY_ANONYMOUS | cSECURITY_SQOS_PRESENT,
) 0
)
except win32pipe.error as e:
# See Remarks:
# https://msdn.microsoft.com/en-us/library/aa365800.aspx
if e.winerror == cERROR_PIPE_BUSY:
# Another program or thread has grabbed our pipe instance
# before we got to it. Wait for availability and attempt to
# connect again.
win32pipe.WaitNamedPipe(address, RETRY_WAIT_TIMEOUT)
return self.connect(address)
raise e
self.flags = win32pipe.GetNamedPipeInfo(handle)[0] self.flags = win32pipe.GetNamedPipeInfo(handle)[0]
self._handle = handle self._handle = handle
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment