nginx学习整理

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是一个线程
    所以,能同时处理的请求只要一个。
    只是在请求间进行不断地切换而已,切换也是因为异步事件未准备好,而主动让出的。
    这里的切换是没有任何代价,你可以理解为循环处理多个准备好的事件,事实上就是这样的。
    与多线程相比,这种事件处理方式是有很大的优势的,不需要创建线程,每个请求占用的内存也很少,没有上下文切换,
    事件处理非常的轻量级。并发数再多也不会导致无谓的资源浪费(上下文切换)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值