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教程有兴趣的朋友有所帮助。

09-19 00:15