nginx
nginx是一个高性能HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器。
能够支持高达5w以上并发连接数的响应,nginx选择了epoll/kqueue作为网络IO模型。
nginx也可以作为负载均衡服务器,nginx使用c语言编写。
nginx是一个主进程和多个工作进程,工作进程是单线程的。每个工作进程可以采用异步非阻塞的方式处理客户端请求。
【扩展学习 异步非阻塞 以及epoll select poll kqueue】
nginx中php是以fastcgi的方法结合nginx。
客户端发送请求给nginx服务器,nginx服务器通过fastcgi将这个请求交给php进行处理,php处理的结果通过fastcgi返回给nginx服务器
之后nginx服务器再将结果返回给客户端。
fastcgi的知识
cgi是一种通用网关接口 是外部应用程序和web服务器之间的接口标准,在外部应用程序和web服务器之间传递信息的规程。
cgi规范允许web服务器执行外部程序,并将它们输出发送给web浏览器。
fastcgi是对cgi的一种改进。
fastcgi像是一个常驻内存型的cgi,当请求到达时cgi会先fork出一个进程来进行处理这个请求
但是fastcgi在启动载入时,就启动多个cgi解释器,并等待web服务器的连接。
当客户端请求到达webserver的时候,fastcgi进程管理器会选择一个cgi解释器来处理这个请求。
好处是cgi解释器被载入内存不需要每次需要的时候从存储器中读取,极大提高了站点的性能
fastcgi的问题是修改php配置的时候不能立刻生效。需要reload一下。
阻塞
客户端的一个请求过来,web服务器接收这个请求,这个请求需要进行io操作,
io操作需要耗费10秒,那么web服务器就等待10秒,在这10秒的时间里,web服务器拒绝其他的客户端请求。
非阻塞
一个客户端的请求过来,web服务器接收这个请求,这个请求需要进行io操作,并且io需要耗时10秒
web服务器在io操作的这10秒里,还是可以接收其他客户端请求,web服务器将这些请求的文件描述符放到一个队列里,当io操作准备好
就将数据发送给这个客户端。
异步非阻塞io模型
一个master线程 和多个worker线程 ,一个worker线程可以处理多个请求,如果请求的事件没有处理好,那么就将这个事件文件描述符放到一个队列中
当事件处理好之后,再去读请求返回的结果,所以可以处理大量的并发请求,当然这里的并发只是没有处理完的请求,由于worker是一个线程
所以,能同时处理的请求只要一个。
只是在请求间进行不断地切换而已,切换也是因为异步事件未准备好,而主动让出的。
这里的切换是没有任何代价,你可以理解为循环处理多个准备好的事件,事实上就是这样的。
与多线程相比,这种事件处理方式是有很大的优势的,不需要创建线程,每个请求占用的内存也很少,没有上下文切换,
事件处理非常的轻量级。并发数再多也不会导致无谓的资源浪费(上下文切换)
以上就介绍了nginx学习整理,包括了nginx方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
Stellungnahme:Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn