Я построил сервер для использования именованного канала Windows, используя следующий код ключа:
def run( self ):
# This is the main server loop for the Win32 platform
import win32pipe
import win32file
self.pipeHandle = win32pipe.CreateNamedPipe(
'\\\\.\\pipe\\myapp_requests',
win32pipe.PIPE_ACCESS_DUPLEX,
win32pipe.PIPE_TYPE_BYTE |
win32pipe.PIPE_READMODE_BYTE |
win32pipe.PIPE_WAIT,
1,
4096,
4096,
10000,
None)
if self.pipeHandle == win32file.INVALID_HANDLE_VALUE:
print 'Failed to create named pipe %s!' % self.pipeName
print 'Exiting...'
sys.exit(1)
while True:
# Open file connection
win32pipe.ConnectNamedPipe( self.pipeHandle )
# Run the main message loop until it exits, usually because
# of a loss of communication on the pipe
try:
self.messageLoop()
except ServerKillSignal:
break
# Return the pipes to their disconnected condition and try again
try: win32pipe.DisconnectNamedPipe( self.pipeHandle )
except: pass
win32file.CloseHandle( self.pipeHandle )
print "Exiting server"
Метод messageLoop()
читает данные из канала, используя win32file.ReadFile()
, до тех пор, пока не будет выдан win32file.error. Затем он выходит, позволяя run () перезапустить его.
В моей реализации пользователи вряд ли имели доступ администратора, поэтому его нельзя было запускать как системную службу. Вместо этого я кодировал клиента для проверки наличия канала в '\. \ Pipe \ pyccf_requests'. Если он не существует, клиент запускает новый процесс на сервере.