一.Nginx简单介绍
Nginx 是俄罗斯人编写的十分轻量级的 HTTP 服务器,Nginx,它的发音为“engine X” , 是一个高性能的 HTTP 和反向代理服务器,同时也是一个IMAP/POP3/SMTP 代理服务器。Nginx 是由俄罗斯人 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发。
Nginx 专为性能优化而开发,性能是其最重要的考量,实现上非常注重效率。它支持内核 Poll 模型,能经受高负载的考验,有报告表明能支持高达 50,000 个并发连接数。
Nginx 具有很高的稳定性。其它 HTTP 服务器,当遇到访问的峰值,或者有人恶意发起慢速连接时,也很可能会导致服务器物理内存耗尽频繁交换,失去响应,只能重启服务器。
例如当前 apache 一旦上到 200 个以上进程,web响应速度就明显非常缓慢了。而 Nginx 采取了分阶段资源分配技术,使得它的CPU 与内存占用率非常低。 nginx 官方表示保持 10,000 个没有活动的连接,它只占 2.5M 内存,所以类似 DOS 这样的攻击对 nginx 来说基本上是毫无用处的。就稳定性而言,nginx 比 lighthttpd 更胜一筹。Nginx 支持热部署。它的启动特别容易, 并且几乎可以做到 7*24 不间断运行,即使运行数个月也不需要重新启动。你还能够在不间断服务的情况下,对软件版本进行进行升级。
二.Nginx优势
1.IO多路复用epoll模型
1.1 什么是IO复用?
IO复用:由内核提供的一种同时监控多个文件描述符状态的功能。
例如:当进程需要操作多个IO相关描述符时,服务器程序要同时查看监听socket和大量业务socket是否有数据到来,需要内核能够监控许多描述符,一旦这些描述符,就绪,就主动告诉进程哪些描述符就绪,站在进程的角度上,就不需要挨个查看每个文件的描述符。

1.2 什么是IO多路复用?
多个描述符的I/O操作都能在一个线程内并发交替的顺序完成
1.3 IO多路复用epoll
实现方式有三种:
1.select
缺点:能够监视文件描述符的数量存在最大限制;线性扫描效率低下
优点:windows、linux都支持
2.epoll
优点:没有最大并发连接限制;效率提升,不是轮询的方式。
2.轻量级
2.1 功能模块少
2.2 代码模块少
3.CPU亲和
CPU亲和是一种把CPU核心跟nginx工作进程绑定在一起,把每个worker进程固定在一个CPU上执行,减少切换CPU的cache miss,获得更好的性能。

4.可以高并发
官方测试Nginx能够支撑5万并发连接,实际生产环境中只能抗住2-4万的并发
采用最新的epoll和kqueue网络I/O模型,而传统的Apache 使用的select模型,消耗CPU比较高。
5.内存消耗少
6.稳定性高
用于方向代理
2.Nginx的基本功能
2.1 处理静态文件
2.2 反向代理加速
2.3 通过fastcgi,简单的负载均衡和容错。
2.4 SSL 支持
2.5 模块化
3.Nginx应用场景
3.1 静态请求
3.2 反向代理
3.3 负载均衡
3.4 资源缓存
3.5 安全防护
3.6 访问限制IP
3.7 访问认证
4.Nginx代理
4.1 Nginx的正向代理
正向代理换言之,就是客户端知道目标主机地址,目标服务器只需要知道哪个代理服务器,不清楚来自哪个具体的客户端,正向代理屏蔽了或隐藏了真实客户端信息
4.2 Nginx的反向代理服务器
客户端请求的是代理服务器,并不住地后端的目标服务器
网友评论