一、概述
Nginx 是一款轻量级的 Web 服务器、反向代理服务器,由于它的内存占用少,启动极快,高并发能力强,在互联网项目中广泛应用。Nginx 专为性能优化而开发,使用异步非阻塞事件驱动模型。
特点:
- 它可以高并发连接,官方测试能够支撑 5 万并发连接,在实际生产环境中可以支撑 2 到 4 万并发连接。
- 内存消耗少
- 稳定性高,用于反向代理(负载均衡),宕机的概率微乎其微。
- 支持热部署。在不间断服务的情况下,对软件版本升级。
二、应用场景
1. HTTP 服务器
Nginx 本身也是一个静态资源的服务器,当只有静态资源的时候,就可以使用 Nginx 来做为服务器,如果一个网站只是静态页面的话,那么就可以通过这种方式来实现部署。
2. 反向代理
反向代理应该是 Nginx 使用最多的功能了,反向代理(Reverse Proxy)方式是指以代理服务器来接收 Internet 上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给 Internet 上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。
3. 负载均衡
负载均衡也是 Nginx 常用的一个功能,负载均衡就是一个 Web 服务器解决不了的问题可以通过多个 Web 服务器来平均分担压力来解决,并发过来的请求被平均分配到多个后台 Web 服务器来处理,这样压力就被分解开来。
4. 动静分离
动静分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化处理的核心思路。
三、目录结构
最常用的三个目录:
- conf/下nginx.conf是配置文件
- sbin/下的ningx是启动nginx服务的文件
- logs/目录下是nginx日志文件:
access.log:程序日志
error.log: 错误日志
nginx.pid: nginx主进程号
四、Nginx进程模型
Nginx服务由一个Master主进程和多个Worker子进程组成。其中,Master主进程的职责是:
- 接收外界信号,如启动,停止,退出,重启等信号。
- 接收子进程worker的信号,监控worker子进程的运行状态,自动重启新的worker进程。
子进程的主要职责是:
与客户端建立连接,接收客户端的请求,并给客户端进行响应。
如下图所示:
再看下图,体会nginx进程的执行流程:
首先,Nginx启动时,先启动Master进程,然后Master进程读取conf配置文件,并进行校验。校验完毕后,根据配置文件的worker数启动子进程。然后子进程接收并响应客户端的请求,读取Nginx的静态资源等操作。Master进程监听worker状态,当有worker挂了时,会主动再启动新的worker进程。
五、 Nginx I/O模型
六、 Tengine与OpenResty
Tengine和OpenResty都是基于Nginx衍生出来的两种web服务器。Tengine官网已经停更很久了,这里我们不再过多描述。
OpenResty官网
OpenResty® 是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。
OpenResty® 通过汇聚各种设计精良的 Nginx 模块(主要由 OpenResty 团队自主开发),从而将 Nginx 有效地变成一个强大的通用 Web 应用平台。这样,Web 开发人员和系统工程师可以使用 Lua 脚本语言调动 Nginx 支持的各种 C 以及 Lua 模块,快速构造出足以胜任 10K 乃至 1000K 以上单机并发连接的高性能 Web 应用系统。
OpenResty® 的目标是让你的Web服务直接跑在 Nginx 服务内部,充分利用 Nginx 的非阻塞 I/O 模型,不仅仅对 HTTP 客户端请求,甚至于对远程后端诸如 MySQL、PostgreSQL、Memcached 以及 Redis 等都进行一致的高性能响应。