进程池监听同一端口失败的原因及其解决方法
在 python 中使用进程池时,如果希望多个进程监听同一个端口,会出现一个常见错误:oserror: [errno 48] address already in use。
这是一个因将其监听套接字绑定的代码,即 serversocket = init_serversocket(),放置在进程池之外而引起的错误。这意味着在每个进程中,serversocket 都被重新初始化并绑定到相同的端口,从而导致端口冲突。
要解决此问题,应将 serversocket 的初始化代码移至主进程中。这样,所有进程都将使用同一个监听套接字,从而消除端口冲突。以下是对原始代码的修改:
立即学习“Python免费学习笔记(深入)”;
def start_request_callback(future: Future) -> None: send_len: int = future.result() logger.debug( f'{threading.current_thread().name}, send payload len is {send_len}') if __name__ == "__main__": serversocket = init_serversocket() pool = multiprocessing.Pool(processes=2) while True: clientsocket, addr = serversocket.accept() clientsocket: socket.socket addr: tuple # future: Future = pool.submit(start_request, clientsocket, addr) # future.add_done_callback(start_request_callback) pool.apply_async(start_request, (clientsocket, addr)) pool.close() pool.join()
在修改后的代码中,serversocket 在主进程中初始化。现在,所有进程将共享同一个 serversocket,并能够监听同一端口。