为什么多线程通常与多处理相结合?

时间:2017-12-26 12:45:35

标签: multithreading apache multiprocessing

作为一个学校项目,我必须实现一个http服务器,所以我正在查看现有的http服务器架构,我遇到了工作人员多处理模块。

这个模块实现了一个混合多线程多进程服务器,它就是forks,每个分叉进程产生自己的线程池来处理请求。

这让我想知道,混合多进程多线程程序相对于多线程程序有什么优势?为什么不保留一个进程并生成一个更大的线程池呢?

1 个答案:

答案 0 :(得分:3)

状况。

你的程序有新生的缺陷,所以最好让一个实例与M个线程崩溃而不是崩溃N * M个线程。 (N-1)* M个其他线程可能能够继续运行,并且您可能已经降低了任何线程崩溃的可能性。

这也被用作处理资源泄漏的技术:在处理N个事务之后,服务器“exec”本身,它导致其资源的清理。我很确定Thompson& Ritchie没有预见到作为执行官的用例....