Nginx如何处理HTTP请求?

nev*_*ame 57 apache nginx

我理解Apache使用的线程驱动:每个连接都打开一个线程,当响应发送时,线程被关闭,释放其他线程的资源).

但我没有得到Nginx使用的事件驱动设计.我已经阅读了一些关于事件驱动设计的基础知识..但我不明白nginx如何使用它来处理Web请求.

我在哪里可以阅读和理解Nginx如何以事件驱动的方式处理连接,所以我明白为什么它更好,而不仅仅是接受基于事件的设计比线程驱动的设计更好.

One*_*one 55

Nginx使用Reactor模式.基本上,它是单线程的(但可以分叉几个进程来利用多个核心).主事件循环等待OS发出准备事件的信号 - 例如,该数据可用于从套接字读取,此时它被读入缓冲区并进行处理.单个线程可以非常有效地为数万个并发连接提供服务(由于每个线程需要自己的堆栈,因为大量的上下文切换开销以及大量的内存消耗,因此每个连接的线程模型都会失败) .

  • 但如果一个线程可以为数万用户提供服务,为什么不使用多个线程来提供更多服务?或者我弄错了. (4认同)
  • @TjerkW:Nodejs会遇到类似的"问题",因为它使用少量线程.但这一切都不是问题,因为它使用的是异步模型,它不会等待响应,而是熄灭并提供其他请求然后返回并在响应缓慢后立即完成响应. (4认同)
  • "如果一个线程可以为成千上万的用户提供服务,那么为什么不使用多个线程"---线程是一个被发明用来减少代价高昂的流程的kludge,代价是复杂性增加.进行异步I/O的重点是,您可以在一个进程中处理许多客户端并从窗口中获取线程.我很确定你不会在异步I/O领域看到任何性价比上涨的价格. (3认同)
  • 如果nginx位于python服务器之前怎么办?而python脚本需要花费大量时间来处理.http://site.com/long-duration-request因为它是一个线程所有其他线程必须等待造成巨大的交通堵塞吗?如果您的应用程序本身是以心态编写的,那么您真的可以从nginx中受益吗?你应该使用像nodejs这样的东西吗? (3认同)
  • 因为反应器必须执行非线程安全操作,例如从套接字读取.使用Proactor模式可以实现多线程(一个固定的工作线程池,例如每个CPU一个),它的工作方式略有不同 - 例如操作系统将读取的数据放入缓冲区(在异步开始时指定缓冲区)操作).但是这个先行者有其自身的缺点 - 它必须为缓冲区保留更多内存; 当只使用单个CPU时,它在Linux上也会变慢. (2认同)
  • @user345602,现代内核允许一个线程同时等待多个套接字上的事件。例如,请参见 https://en.wikipedia.org/wiki/Epoll。 (2认同)