◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
线程池无法绑定相同端口的原因
在本文档中,开发者试图实现类似 nginx、gunicorn 等 master-slave 架构,其中多个进程监听相同的端口。然而,在使用 python 的进程池时遇到了 oserror,提示“地址已被使用”。
原因在于,调用 init_serversocket 函数初始化服务端套接字的代码放置在了 main 函数之外。根据所引用的博客文章,只有在 fork 子进程之前调用 bind 才是允许的。
解决方法
立即学习“Python免费学习笔记(深入)”;
要解决此问题,只需将以下代码移动到 main 函数中:
serversocket = init_serversocket()
通过在 main 函数中初始化服务端套接字,在创建子进程之前完成了 bind 操作。这将允许所有进程使用相同的端口,实现预期的 master-slave 架构。
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。