过去最主流的服务器是 1995 年发布的 Apache 1.0。Apache 源于 NCSAHTTPd 服务器,是一个多进程模型的 Web 服务器。但运行到后期,Apache 渐渐出现很多问题,比如内存占用很大、扩展需挂接第三方库、并发能力受限等。2004 年 10 月,新的 Web 服务器 Nginx 1.0 横空出世。该服务器采用“多进程+I/0 复用+扩展静态编译到主进程”的并发模型,被一直沿用至今。
Nginx 经过十余年的发展,已经演变成非常成熟的 Web 服务器、代理接入服务器。目前,Nginx 在全球 Web 服务器市场中的份额约为 38%,超过了 Apache 服务器全球 25%的市场份额,为全球各类 Web/API 服务器提供接入服务,满足用户的各种访问需求。
Nginx 弥补了过去大部分服务端软件依赖于操作系统提供的类似于 libc/glibc 等基础库的不足,其内部的主流数据结构算法全部自主实现,包括进程管理、内存管理、异步网络 I/O 封装、各种均衡策略、网络代理、HTTP 处理等,还具备强大的扩展挂接机制,已经成为高性能服务器开发的典范。
总的来说 NGINX 已经成为现在非常主流的服务器,使用的也非常广泛,但是当下市面上对于 NGINX 的书籍少之又少,所以今天小编就给大家分享出一份由资深专家写的 Nginx 底层与源码分析手册,下面和我一起看看吧!
Nginx 优势
Nginx 是一个 Web 服务器,可以用于反向代理、负载均衡等场合。Nginx 具有以下优点。
高性能:相比于其他 Web 服务器(例如 Apache),Nginx 在正常请求以及高峰请求期,可以更快地响应请求。
高可靠:Nginx 采用多进程模型,具体分为主进程和工作进程。主进程负责监视工作进程,当工作进程异常退出时,可以快速拉起一个新的工作进程,从而为用户提供稳定服务。它在工业上的广泛应用也充分证明了这一点。
高并发:Nginx 通常作为网关级服务,其支持的并发量通常在万级别,经过优化甚至可以达到十万级别。
易扩展:Nginx 是模块化设计,具有极高的扩展性,使用者可以根据自身需求,定制开发相应模块。
热部署:Nginx 提供了优雅重启以及平滑升级的方案,使用户在修改配置文件或者升级 Nginx 时,不会影响线上服务。
跨平台:Nginx 支持多种平台,例如 Linux、Windows、macOS。
Nginx 源码结构
Nginx 进程模型
Nginx 模块化设计
基本数据结构
Nginx 进程机制
HTTP 请求解析
Upstream 简介
限于文章篇幅原因,就展示到这里了,有需要的小伙伴 +文末wx名片即可领取