Nginx反向代理架构介绍

news2025/1/19 19:00:43

Nginx反向代理架构是一种强大的服务器架构模式,它位于用户和原始服务器之间,接收用户的请求并将其转发到一个或多个后端服务器,然后将从后端服务器获取的响应返回给用户,就好像这些内容都是由代理服务器本身直接提供的一样。以下是对Nginx七层反向代理架构的详细剖析:

文章目录

      • 一、工作原理
      • 二、核心优势
      • 三、配置示例
      • 四、特殊场景应用
      • 五、Nginx进程模型
      • 六、Nginx线程模型
      • 七、Nginx进程及线程模型的优势

一、工作原理

  1. 请求接收与解析

    • Nginx接收到客户端的HTTP请求后,会解析请求的URL、HTTP头部信息等,以理解请求的具体内容和目标。
  2. 配置规则查找

    • 基于解析的结果,Nginx会查找其配置规则,确定应该将请求转发到哪个后端服务器。这个选择过程可能涉及多种因素,如URL路径、请求类型、负载均衡算法等。
  3. 请求转发

    • Nginx会建立一个到选定后端服务器的新连接(除非使用了连接池),并将原始请求转发给这个后端服务器。在转发过程中,Nginx可能会修改某些HTTP头部信息,例如添加表示真实客户端IP的X-Forwarded-For头部。
  4. 响应处理

    • 后端服务器接收到请求后,会处理这个请求并生成响应。这个响应会被发送回Nginx。
    • Nginx接收到后端服务器的响应后,可能会对响应进行一些处理,例如添加或修改某些HTTP头部,或者对响应内容进行压缩。
  5. 响应返回

    • 最后,Nginx将处理后的响应发送回原始客户端。从客户端的角度来看,整个过程就像是直接与Nginx通信,而不知道后端服务器的存在。

二、核心优势

  1. 负载均衡

    • 当有多个后端服务器时,Nginx可以根据预定义的规则将请求分发到不同的服务器,从而平衡各服务器的负载,提高整体系统的性能和可用性。
  2. 安全性增强

    • 通过隐藏后端服务器的真实IP地址和架构细节,Nginx可以有效地保护后端资源免受直接攻击。
    • 此外,Nginx还可以集中实施安全策略,如SSL/TLS加密、请求过滤等。
  3. 缓存优化

    • Nginx可以缓存静态内容和一些动态内容,减轻后端服务器的压力,同时提高响应速度。
  4. 灵活的请求路由

    • 通过配置不同的路由规则,Nginx可以将不同类型的请求导向不同的后端服务,实现微服务架构或者API网关的功能。
  5. 系统扩展性

    • Nginx允许通过添加或移除后端服务器来调整系统容量,客户端无需感知这些变化。这种透明的扩展能力有助于应对流量波动和系统升级。

三、配置示例

在Nginx中,反向代理的配置主要在http块内的server块中进行。一个基本的反向代理配置示例如下:

http {
    server {
        listen 80;
        server_name example.com;
        
        location / {
            proxy_pass http://backend_server;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
        }
    }
}

在这个配置中:

  • 定义了一个监听80端口的服务器,它将接收所有发往example.com的请求。
  • location /块指定了对根路径“/”的处理规则,这里使用proxy_pass指令将请求转发到后端服务器http://backend_server
  • proxy_set_header指令用于设置或修改发送给后端服务器的请求头。

四、特殊场景应用

除了基本的反向代理功能外,Nginx还支持一些特殊场景的应用,例如:

  1. UWSGI协议支持

    • 对于使用UWSGI协议的Web应用,Nginx可以通过uwsgi_pass指令将请求转发到运行UWSGI协议的后端服务器。
    • UWSGI协议是一种二进制协议,专为Web服务器和Web应用程序之间的通信而设计,相比HTTP协议具有更高的效率。
  2. 高并发处理

    • Nginx采用事件驱动的架构和非阻塞I/O模型,能够同时处理大量的并发连接,而不需要为每个连接创建一个新的线程或进程。
  3. HTTPS支持

    • 对于需要处理HTTPS请求的场景,Nginx可以在server块中配置SSL/TLS,以确保数据传输的安全性。

五、Nginx进程模型

Nginx采用的是主进程和工作进程(worker processes)的模型。在这种模型中,Nginx会启动一个主进程(Master Process)和多个工作进程(Worker Processes)。

  1. 主进程(Master Process)

    • 主要职责是配置文件的解析和工作进程的管理。
    • 负责读取和验证配置文件(nginx.conf),在配置文件发生变化时(如使用nginx -s reload命令时),它会重新加载配置文件而无需重启服务。
    • 负责创建、监控和结束工作进程的生命周期。
    • 可以接收系统信号(如重启、停止等),并根据信号进行相应的操作,例如重新加载配置文件或优雅地关闭工作进程。
  2. 工作进程(Worker Processes)

    • 是实际处理客户端请求的进程。
    • 通常情况下,会根据服务器的CPU核心数量来设置工作进程的数量,以便充分利用多核处理器的优势。
    • 每个工作进程都是独立的,它们运行在独立的内存空间中,并且通常不进行父子进程间的通信。
    • 工作进程通过竞争方式来处理来自客户端的连接和请求。当一个客户端连接到达时,Nginx会根据特定的算法(如轮询)选择一个工作进程来处理该连接。
    • 工作进程负责从接收请求、解析、处理到响应的全过程。

六、Nginx线程模型

虽然Nginx主要基于多进程模型,但它在代码中提供了一个thread_pool(线程池)的核心模块来处理多任务。这个模块是可选的,并且需要手动配置才能启用。

  1. 线程池配置

    • 配置语法:thread_pool name threads=number [max_queue=number];其中,name是线程池的名称,threads=number指定了线程池中的线程数量,max_queue=number指定了队列的最大长度。
  2. 工作原理

    • 每个工作进程可以配置一个或多个线程池。
    • 当工作进程需要处理大量I/O密集型任务时(如磁盘读写、网络通信等),它可以将这些任务交给线程池来处理。
    • 线程池中的线程会并发地执行这些任务,从而提高处理效率。

然而,需要注意的是,Nginx的线程池模块并不是其主要的并发处理机制。在大多数情况下,Nginx的多进程和异步非阻塞处理机制已经足够满足高并发的需求。线程池模块主要用于处理一些特定的、需要并发执行的任务。

七、Nginx进程及线程模型的优势

  1. 高并发处理能力

    • Nginx通过多进程和异步非阻塞的处理机制,能够高效地处理大量的并发连接,而不会显著增加资源消耗。
  2. 稳定性和可靠性

    • 如果一个工作进程崩溃,它不会影响其他工作进程,主进程可以简单地启动一个新的工作进程来替代。这种设计提高了系统的稳定性和可靠性。
  3. 内存使用高效

    • 工作进程的独立性意味着内存使用更加高效,因为不需要为所有请求维护一个单一的大型内存空间。
  4. 灵活性和可扩展性

    • Nginx的进程和线程模型允许根据服务器的硬件资源和应用场景进行灵活的配置和调整,以满足不同的性能需求。

综上所述,Nginx的七层反向代理架构通过其高效的工作机制、丰富的功能和灵活的配置选项,成为构建现代Web应用架构的理想选择。Nginx的进程及线程模型是其高性能和高并发处理能力的关键所在。通过合理配置和调整Nginx的进程和线程数量以及线程池参数,可以充分发挥Nginx的性能优势,满足各种应用场景的需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2279031.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vulnhub靶场【Lampiao靶机】,主要考察提权,脏牛提权

前言 靶机:lampiao,IP地址为192.168.10.11 攻击:kali,IP地址为192.168.10.2 都采用虚拟机,网卡为桥接模式 该靶机目前只剩下一个了,之前记得是有两台构成系列的。 文章中涉及的靶机,来源于v…

ASP .NET Core 学习(.NET9)配置接口访问路由

新创建的 ASP .NET Core Web API项目中Controller进行请求时,是在地址:端口/Controller名称进行访问的,这个时候Controller的默认路由配置如下 访问接口时,是通过请求方法(GET、Post、Put、Delete)进行接口区分的&…

构建core模块

文章目录 1.环境搭建1.sunrays-common下新建core模块2.引入依赖,并设置打包常规配置 2.测试使用1.启动!1.创建模块2.引入依赖3.application.yml 配置MySQL和Minio4.创建启动类5.启动测试 2.common-web-starter1.目录2.WebController.java3.结果 3.common…

VRTK4 记录抓取错误

左手原本可以正常抓取,但是当右手拿起一个物体时,左手抓取右手的线性驱动器,只有部分区域可以抓取 原因是左手的判定物体的层级错误 应该在Collections下,之前错误的和Collections同一层级,导致抓取有时可以有时不可以…

游戏画质升级史的思考

画质代入感大众玩家对游戏的第一印象与评判标准 大众玩家还没到靠游戏性等内在因素来评判游戏的程度。 画面的重要性,任何时候都不能轻视。 行业就是靠摩尔定律来推动进步的。 NS2机能达到PS4到PS4PRO之间的水准,5050达到8G显存,都会引发连…

Windows11电脑总是一闪一闪的,黑一下亮一些怎么解决

Windows11电脑总是一闪一闪的,黑一下亮一些怎么解决 1. 打开设备管理器2. 点击显示适配器3. 更新下方两个选项的驱动3.1 更新驱动Inter(R) UHD Graphixs3.2 更新驱动NVIDIA GeForce RTX 4060 Laptop GPU 4. 其他文章快来试试吧🥰 1. 打开设备管理器 在电…

【RAG落地利器】向量数据库Qdrant使用教程

TrustRAG项目地址🌟:https://github.com/gomate-community/TrustRAG 可配置的模块化RAG框架 环境依赖 本教程基于docker安装Qdrant数据库,在此之前请先安装docker. Docker - The easiest way to use Qdrant is to run a pre-built Docker i…

【逆境中绽放:万字回顾2024我在挑战中突破自我】

🌈个人主页: Aileen_0v0 🔥热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​💫个人格言:“没有罗马,那就自己创造罗马~” 文章目录 一、引言二、个人成长与盘点情感与心理成长学习与技能提升其它荣誉 三、年度创作历程回顾创作内容概…

HTTP / 2

序言 在之前的文章中我们介绍过了 HTTP/1.1 协议,现在再来认识一下迭代版本 2。了解比起 1.1 版本,后面的版本改进在哪里,特点在哪里?话不多说,开始吧⭐️! 一、 HTTP / 1.1 存在的问题 很多时候新的版本的…

于灵动的变量变幻间:函数与计算逻辑的浪漫交织(下)

大家好啊,我是小象٩(๑ω๑)۶ 我的博客:Xiao Xiangζั͡ޓއއ 很高兴见到大家,希望能够和大家一起交流学习,共同进步。 这一节我们主要来学习单个函数的声明与定义,static和extern… 这里写目录标题 一、单个函数…

pthread_create函数

函数原型 pthread_create 是 POSIX 线程&#xff08;pthread&#xff09;库中的一个函数&#xff0c;用于在程序中创建一个新线程。 #include <pthread.h>int pthread_create(pthread_t *thread, const pthread_attr_t *attr,void *(*start_routine) (void *), void *a…

VSCode 的部署

一、VSCode部署 (1)、简介 vsCode 全称 Visual Studio Code&#xff0c;是微软出的一款轻量级代码编辑器&#xff0c;免费、开源而且功能强大。它支持几乎所有主流的程序语言的语法高亮、智能代码补全、自定义热键、括号匹配、代码片段、代码对比Diff、版本管理GIT等特性&…

模之屋模型导入到UE5

去模之屋随便下个模型 安装Blender2.8 插件 cats-blender-plugin &#xff0c; 打开blender 2.8转换 pmx转换fbx https://github.com/absolute-quantum/cats-blender-plugin Index of /release/Blender2.80/ 修改单位 修复贴图 更高清了 点fix model 修复模型 改为编辑模式…

用Cursor生成一个企业官网前端页面(生成腾讯、阿里官网静态页面)

用Cursor生成一个企业官网前端页面 第一版&#xff1a; <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><…

css 实现自定义虚线

需求&#xff1a; ui 画的图是虚线&#xff0c;但是虚线很宽正常的border 参数无法做到 进程&#xff1a; 尝试使用 border&#xff1a;1px dashed 发现使用这个虽然是虚线但是很短密密麻麻的 这并不是我们想要的那就只能换方案 第一个最简单&#xff0c;让ui 画一个图然…

【鸿蒙】0x02-LiteOS-M基于Qemu RISC-V运行

OpenHarmony LiteOS-M基于Qemu RISC-V运行 系列文章目录更新日志OpenHarmony技术架构OH技术架构OH支持系统类型轻量系统&#xff08;mini system&#xff09;小型系统&#xff08;small system&#xff09;标准系统&#xff08;standard system&#xff09; 简介环境准备安装QE…

力扣动态规划-2【算法学习day.96】

前言 ###我做这类文章一个重要的目的还是给正在学习的大家提供方向&#xff08;例如想要掌握基础用法&#xff0c;该刷哪些题&#xff1f;建议灵神的题单和代码随想录&#xff09;和记录自己的学习过程&#xff0c;我的解析也不会做的非常详细&#xff0c;只会提供思路和一些关…

细说STM32F407单片机电源低功耗SleepMode模式及应用示例

目录 一、STM32F4的低功耗模式 1、睡眠(Sleep)模式 2、停止(Stop)模式 3、待机(Standby)模式 二、睡眠模式 1、进入睡眠模式 2、睡眠模式的状态 3、退出睡眠模式 4、SysTick的影响 三、应用示例 1、工程配置 &#xff08;1&#xff09; 时钟、DEBUG、GPIO、CodeGen…

【竞技宝】LOL:ning直播再次锐评

北京时间1月18日,目前英雄联盟LPL2025正在如火如荼的进行之中,很多队伍都已经打完了新赛季的首场比赛,其中就包括AL战队,AL在休赛期进行了大幅度的人员调整,整体实力相比之前增强了不少,在16日的比赛中,AL3-0轻松击败LGD拿下了赛季开门红,而AL的打野选手tarzan在本场比赛中表现…

构建安全防线:基于视频AI的煤矿管理系统架构创新成果展示

前言 本文我将介绍一款AI产品的成果展示——“基于视频AI识别技术的煤矿安全生产管理系统”。这款产品是目前我在创业阶段和几位矿业大学的博士共同从架构设计、开发到交付的全过程中首次在博客频道发布, 我之前一直想写但没有机会来整理这套系统的架构, 因此我也特别感谢CSDN平…