ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
### 原因一:IO多路复用epoll #### 什么是IO复用 多个描述符的I/O操作都能在一个线程内并发交替的顺序完成,这就叫做I/O多路复用,这里的"复用"指的是复用同一个进程 . IO多路复用有个特点,就是socket会主动上报当前状态 . ![](https://box.kancloud.cn/b2d6d76b4411fe861796c0fddd90f20d_1084x283.png) #### 什么是epoll IO多路复用实现方式select , poll, epoll . 1. 每当FD就绪,采用系统的回调函数之间将fd放入,效率更高 . 2. 最大连接无限制 . ### 原因二:轻量级 #### 功能模块化 源代码只保留了核心功能,那些不够核心或者可以作为插件来安装的功能不会集成在核心代码中 . #### 代码模块化 ### 原因三:CPU亲和(affnity) #### 什么是CPU亲和 是一种把CPU核心和Nginx工作进程绑定方式,把每个worker进程固定在一个CPU上执行,减少切换CPU的cache miss,获得更好的性能 . ![](https://box.kancloud.cn/e598090376688cc2f2f3facbd878a812_1126x311.png) ### 原因四:sendfile 访问静态资源的时候会先在用户空间(Nginx进程空间)申请一个buffer,用read函数把数据从磁盘读到cache,再从cache读取到用户空间的buffer, 再用write函数把数据从用户空间的buffer写入到内核的buffer,最后到tcp socket。使用sendfile后可以让数据不用经过用户buffer。 ![](https://box.kancloud.cn/cd7162630cdf81ae0645cd3d4e67ff62_970x494.png) #### 选择nginx理由 1. 它可以高并发连接,官方测试能够支撑5万并发连接,在实际生产环境中可以支撑2到4万并发连接。 2. 内存消耗少 Nginx+php(FastCGI)服务器再3万并发连接下,开启的10个Nginx进程消耗150MB内存(15MB*10=150MB)开启的64个php-cgi进程消耗1280MB内存(20MB*64=1280MB) 3. 购买F5 BIG-IP ,NetScaler等硬件负载均衡交换机需要10多万甚至几十万人民币。而Nginx为开源软件,可以免费试用,并且可用于商业用途。 4. 配置文件非常简单:通俗易懂,即使非专业管理员也能看懂。 5. 支持 rewrite重写规则:能根据域名、URL的不同,将HTTP请求分到不同的后端服务器群组。 6. 内置的健康检查功能:如果nginx proxy后端的某台服务器宕机了,不会影响前端访问。 7. 节省带宽,支持gzip压缩。 8. 稳定性高:用于反向代理(负载均衡),宕机的概率微乎其微。 9. 支持热部署。在不间断服务的情况下,对软件版本升级。