文章目录
Nginx
定义
- Nginx是一个开源且高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务
- 开源:直接获取源代码
- 高性能:支持海量并发
- 客户端与服务端中间层(可代理java,php,静态文件)
常见HTTP服务
- HTTPD(apache基金会)
- IIS(微软)
- GWS(GOOGLE)
- openrestry(nginx+lua)
- tengline(淘宝基于Nginx)(tengine.taobao.org)
- lighttpd
Nginx 应用场景
- 静态代理
- 反向代理
- 负载均衡(搭理很多台)
- 安全防护
Nginx优秀特性
Nginx基于io多路复用
- 多个描述符的I/O操作都能在一个线程内并发交替的顺序完成,这就叫IO多路复用(复用指的是复用同一个线程)
io复用解决并发性问题,Socket作为复用
多个描述符的io操作都能在一个线程内并发交替地顺序完成,这就叫IO多路复用,
- io复用(串行)
- 产生阻塞,影响后面用户访问
- io复用(并行)
- 多线程,资源消耗大,多线程
- io复用(主动上报)
- 一个操作完成后主动上报
IO多路复用的实现方式有select,poll,Epool
select
发出请求,查看应用,被阻断,则全部停止,直到处理完成,应用把结果返回给内核,完成一个操作的请求,再处理新的请求
- 缺点
- 能够监视文件描述符的数量存在最大限制(每个请求都会打开对应文件描述符,系统内置的文件描述符是1024)
- 线性遍历扫描效率低下
epool模型
- 每当FD(文件描述符)就绪,采用系统的回调函数,将FD放入,效率更高(指出完成的,不用遍历)
- FD(文件描述符):内核为了高效管理已被打开的文件所创建的索引,用于指代被打开的文件,所有执行IO操作的系统调用都通过文件描述符(程序刚刚启动时:0是标准输入,1是标注输出,2是标注错误。如果此时去打开一个新的文件,它的文件描述符是3)
- 最大连接无限制
- 轻量级
- 功能模块少
- 代码模块少(耦合度低)