Python进程池监听同一端口失败:原因及解决方法是什么?

python进程池监听同一端口失败:原因及解决方法是什么?

进程池监听同一端口失败的原因及其解决方法

python 中使用进程池时,如果希望多个进程监听同一个端口,会出现一个常见错误:oserror: [errno 48] address already in use。

这是一个因将其监听套接字绑定的代码,即 serversocket = init_serversocket(),放置在进程池之外而引起的错误。这意味着在每个进程中,serversocket 都被重新初始化并绑定到相同的端口,从而导致端口冲突。

要解决此问题,应将 serversocket 的初始化代码移至主进程中。这样,所有进程都将使用同一个监听套接字,从而消除端口冲突。以下是对原始代码的修改:

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,并能够监听同一端口。

以上就是Python进程池监听同一端口失败:原因及解决方法是什么?的详细内容,更多请关注硕下网其它相关文章!