Nginx简单介绍

第九天

Nginx

1.什么是Nginx,他有什么优势和功能?

Nginx是一个高性能的 Web 服务器、方向代理服务器、负载均衡器。他一般用于反向代理,负载均衡,缓存数据,托管静态网站等。

反向代理,保正高可靠性,实现是Nginx作为客户端和服务端的中介,隐藏了后端架构,用户访问网站,Nginx会监听请求转发到对应的后端服务器,后端处理后,通过反向代理返回给客户端。

负载均衡,是将流量分发到多个后端服务器,避免单点过载,提高可用性。使用流程是nginx监听有请求时,会根据负载均衡算法,轮询,最少连接数等,选择一台后端服务器。将请求发送到选中的服务器。后端处理完成后,结果通过负载均衡器返回客户端。

缓存数据,存储频繁访问的静态或动态内容,减少后端计算和数据库查询

扩展

负载均衡算法

算法 指令示例 适用场景 特点
轮询 (RR) upstream { server1; server2 } 后端服务器性能均衡 默认策略,简单公平
加权轮询 server 10.0.0.1 weight=3 异构服务器(CPU/RAM差异) 性能差的服务器分配较少请求
最少连接 (Least Conn) least_conn 长连接服务(如WebSocket) 动态分配,避免过载
IP哈希 ip_hash 会话保持需求 同一客户端固定访问某服务器
响应时间优先 fair (第三方模块) 对延迟敏感的服务 需安装额外模块

反向代理工作原理

请求处理流程

  1. 请求接收:客户端连接Nginx 80/443端口

  2. 协议解析 :解构HTTP头部,匹配server_name

  3. 路由转发 :根据location规则选择upstream

    复制代码
    location /api/ {
        proxy_pass http://backend;
        proxy_set_header X-Real-IP $remote_addr;
    }
  4. 连接复用 :通过keepalive维持与后端长连接

  5. 响应缓冲 :启用proxy_buffering on避免慢客户端拖慢Worker

关键优化参数
复制代码
proxy_buffer_size 4k;       # 响应头缓冲区
proxy_buffers 8 16k;       # 响应内容缓冲区
proxy_connect_timeout 5s;  # 后端连接超时

2.Nginx是如何处理一个HTTP请求的呢?实现原理是什么?

Nginx的多进程机制

Nginx采用主进程(Master Process)和工作进程(Worker Process)的架构。启动时,主进程会预先创建固定数量的工作进程(通常与CPU核心数相同),而非为每个连接动态创建进程。这些工作进程共享监听套接字,采用事件驱动模型并行处理多个客户端连接。工作进程之间完全独立运行,无需加锁,降低了编程复杂度。当某个工作进程异常退出时,主进程会立即重新启动一个新进程,确保服务的高可用性。这种设计的优势在于避免了动态创建进程的开销,同时通过进程隔离提高了稳定性。但由于采用多进程模型,仍存在一定的内存占用问题,每个工作进程需要维护独立的内存空间。

Nginx的异步非阻塞机制

Nginx的工作进程基于异步非阻塞I/O模型,单个进程可以同时处理数千个连接。当工作进程接收到客户端请求后,如果遇到I/O操作(如磁盘读写或网络通信),会立即将该请求挂起并转去处理其他就绪请求(非阻塞),而客户端在此期间也不会被阻塞(异步)。当I/O操作完成时,操作系统会通过事件通知机制(如epoll或kqueue)唤醒工作进程,后者会根据事件队列继续处理对应的请求。这种机制通过事件驱动和回调函数实现高并发,但要求所有I/O操作都必须是非阻塞的,且应用程序需要适应这种编程范式。

3.请解释Nginx服务器上的Master和Worker进程分别是什么?

Master进程(主进程)

Nginx的管理者,负责全局控制,不直接处理客户端请求。

Worker进程(工作进程)

Nginx的实际工作者,负责处理客户端请求(如HTTP/TCP连接)。

并发请求处理:每个Worker通过事件驱动(epoll/kqueue)非阻塞处理数千连接

动态请求代理:反向代理时,将请求转发到后端(如Node.js/Java)。

相关推荐
ping某1 天前
为什么 Nginx 明明监听了 80,转发后端时却用了 4xxxx 端口?
后端·nginx
大树883 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠3 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质3 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
Inhand陈工3 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
酣大智3 天前
ARP代理--工作原理
运维·网络·arp·arp代理
shushangyun_3 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
施努卡机器视觉3 天前
SNK施努卡侧滑门锁上滑轮总成自动化装配线,从零件到组件,全流程精密制造方案
运维·自动化·制造
AC赳赳老秦3 天前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw
java_cj3 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes