作为一个学校项目,我必须实现一个http服务器,所以我正在查看现有的http服务器架构,我遇到了工作人员多处理模块。
这个模块实现了一个混合多线程多进程服务器,它就是forks,每个分叉进程产生自己的线程池来处理请求。
这让我想知道,混合多进程多线程程序相对于多线程程序有什么优势?为什么不保留一个进程并生成一个更大的线程池呢?
答案 0 :(得分:3)
状况。
你的程序有新生的缺陷,所以最好让一个实例与M个线程崩溃而不是崩溃N * M个线程。 (N-1)* M个其他线程可能能够继续运行,并且您可能已经降低了任何线程崩溃的可能性。
这也被用作处理资源泄漏的技术:在处理N个事务之后,服务器“exec”本身,它导致其资源的清理。我很确定Thompson& Ritchie没有预见到作为执行官的用例....