当前位置: 首页 > backend >正文

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)。

http://www.xdnf.cn/news/16250.html

相关文章:

  • Java-Properties类和properties文件详解
  • 图论:最小生成树
  • classgraph:Java轻量级类和包扫描器
  • linux C — udp,tcp通信
  • 【Chrome】下载chromedriver的地址
  • 深入解析浏览器存储方案:Cookie、localStorage和sessionStorage特性与应用
  • GPU 服务器ecc报错处理
  • Java排序算法之<冒泡排序>
  • 单片机(STM32-ADC模数转换器)
  • 优思学院|QC七大手法之一的检查表应如何有效使用?
  • CSS 盒子模型学习版的理解
  • 数据结构 二叉树(1)
  • yarn在macOS上的安装与镜像源配置:全方位指南
  • 从 SQL Server 到 KingbaseES V9R4C12,一次“无痛”迁移与深度兼容体验实录
  • Orbbec开发---数据流与数据流操作
  • ZLMediaKit 源代码入门
  • Spring 策略模式实现
  • 【DeepRare】疾病识别召回率100%
  • SpringBoot学习路径二--Spring Boot自动配置原理深度解析
  • 教培机构如何开发自己的证件照拍照采集小程序
  • 萤石云替代产品摄像头方案萤石云不支持TCP本地连接-东方仙盟
  • 深入解析Hadoop MapReduce中Reduce阶段排序的必要性
  • 《Uniapp-Vue 3-TS 实战开发》自定义环形进度条组件
  • 人工智能冗余:大语言模型为何有时表现不佳(以及我们能做些什么)
  • 【js】ES2025新语法糖
  • 缓存HDC内容用于后续Direct2D绘制.
  • C#(基本语法)
  • SQLite中SQL的解析执行:Lemon与VDBE的作用解析
  • 机器学习笔记(三)——决策树、随机森林
  • 使用Python绘制金融数据可视化工具