架构——Nginx功能、职责、原理、配置示例、应用场景

news2025/4/3 22:46:35

以下是关于 Nginx 的功能、职责、原理、配置示例、应用场景及其高性能原因的详细说明:


一、Nginx 的核心功能

1. 静态资源服务

  • 功能:直接返回静态文件(如 HTML、CSS、JS、图片、视频等)。
  • 配置示例
    server {
        listen 80;
        server_name example.com;
        root /var/www/html;  # 静态文件根目录
        location / {
            index index.html;
        }
    }
    

2. 反向代理

  • 功能:将客户端请求转发到后端服务器(如 Tomcat、Node.js、Python 应用等),隐藏后端细节。
  • 配置示例
    server {
        listen 80;
        server_name api.example.com;
        location / {
            proxy_pass http://backend_servers;  # 转发到后端服务器组
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
        }
    }
    

3. 负载均衡

  • 功能:将请求分发到多个后端服务器,支持多种负载均衡算法(轮询、权重、IP 哈希等)。
  • 配置示例
    upstream backend_servers {
        server 192.168.1.101:8080 weight=3;  # 权重轮询
        server 192.168.1.102:8080;
        server 192.168.1.103:8080 backup;    # 备用服务器
    }
    

4. SSL/TLS 终止

  • 功能:处理 HTTPS 加密和解密,减轻后端服务器压力。
  • 配置示例
    server {
        listen 443 ssl;
        server_name example.com;
        ssl_certificate /etc/nginx/ssl/example.crt;
        ssl_certificate_key /etc/nginx/ssl/example.key;
        location / {
            proxy_pass http://backend_servers;
        }
    }
    

5. 缓存加速

  • 功能:缓存动态内容或静态资源,减少后端负载并提升响应速度。
  • 配置示例
    proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m inactive=60m;
    server {
        location / {
            proxy_cache my_cache;
            proxy_pass http://backend_servers;
            proxy_cache_valid 200 302 10m;  # 缓存有效时间
        }
    }
    

6. 访问控制与安全

  • 功能:限制 IP 访问、请求速率、防盗链等。
  • 配置示例
    location /admin {
        allow 192.168.1.0/24;  # 允许特定 IP 段
        deny all;              # 拒绝其他 IP
    }
    
    location /uploads {
        valid_referers none blocked example.com;  # 防盗链
        if ($invalid_referer) {
            return 403;
        }
    }
    

7. 日志记录

  • 功能:记录请求日志,支持自定义日志格式。
  • 配置示例
    log_format main '$remote_addr - $remote_user [$time_local] "$request" '
                    '$status $body_bytes_sent "$http_referer" '
                    '"$http_user_agent" "$http_x_forwarded_for"';
    access_log /var/log/nginx/access.log main;
    

二、Nginx 的核心职责

  1. Web 服务器:高效处理静态资源请求。
  2. 反向代理网关:转发请求到后端应用服务器,隐藏后端架构。
  3. 负载均衡器:分配流量到多个服务器,提升系统可用性。
  4. 安全防护层:通过 SSL 加密、访问控制保护后端服务。
  5. 流量管理:实现限流、缓存、压缩(如 Gzip)等优化。

三、Nginx 的工作原理

1. 事件驱动模型

  • 异步非阻塞 I/O
    Nginx 使用 epoll(Linux)或 kqueue(BSD)等系统调用,单线程可处理数千并发连接,避免传统多线程模型的上下文切换开销。
  • 多进程架构
    • Master 进程:负责读取配置、绑定端口、管理 Worker 进程。
    • Worker 进程:实际处理请求的进程,彼此独立,避免资源竞争。
      在这里插入图片描述

2. 请求处理流程

  1. 客户端发起请求到 Nginx 监听端口。
  2. Worker 进程通过事件驱动模型接收请求。
  3. 根据配置匹配 serverlocation 块,执行反向代理、缓存读取等操作。
  4. 若需访问后端服务器,通过负载均衡算法选择目标服务器。
  5. 返回响应给客户端(可能经过缓存或压缩处理)。
    在这里插入图片描述

3. 核心模块化设计

  • 模块分类
    • 核心模块(如 ngx_http_core_module
    • 第三方模块(如 ngx_http_lua_module 支持 Lua 脚本)
  • 动态加载:支持按需加载模块,减少资源占用。

四、Nginx 的应用场景

  1. 静态资源托管
    • 直接托管 HTML、图片等文件,替代 Apache 或 Tomcat。
  2. API 网关
    • 反向代理微服务,统一入口管理鉴权、限流、日志。
  3. 动态内容加速
    • 缓存数据库查询结果或动态页面(如电商商品页)。
  4. 高并发负载均衡
    • 分配请求到多台应用服务器(如抢购场景)。
  5. SSL 卸载
    • 集中处理 HTTPS 加解密,降低后端服务器压力。
  6. 灰度发布
    • 通过流量切分(如按比例或 IP)测试新版本服务。

五、Nginx 高性能的原因

1. 事件驱动与非阻塞 I/O

  • 单线程处理大量连接,避免多线程/进程的上下文切换开销。

2. 高效内存管理

  • 零拷贝技术:通过 sendfile 系统调用直接传输文件,减少内核态与用户态数据拷贝。
  • 内存池机制:预分配内存块,减少频繁的内存申请释放操作。

3. 多进程架构

  • Worker 进程独立运行,避免锁竞争,充分利用多核 CPU。

4. 轻量级设计

  • 模块化架构,核心代码精简,第三方模块按需加载。

5. 配置优化友好

  • 支持连接复用(Keep-Alive)、响应压缩(Gzip)、缓存等优化策略。

六、Nginx 的优缺点

优点

  • 高并发处理能力(单机支持数万并发连接)。
  • 低内存消耗(静态资源处理尤其高效)。
  • 灵活的配置和模块化扩展。
  • 广泛的应用场景和社区支持。

缺点

  • 动态内容处理依赖后端服务(如 PHP 需配合 FastCGI)。
  • 复杂配置需一定学习成本。
  • 原生不支持动态模块热加载(需重启生效)。

七、总结

Nginx 凭借其事件驱动模型、高效资源管理和模块化设计,成为现代 Web 架构的核心组件。无论是作为静态服务器、反向代理,还是负载均衡器,Nginx 都能显著提升系统性能和可靠性。合理配置其缓存、压缩、负载均衡策略,可应对高并发、大流量场景(如电商大促、在线教育等)。

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

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

相关文章

涉密载体管控系统革新:RFID技术引领,信息安全新境界

行业背景 文件载体管控系统DW-S402是用于对各种SM载体进行有效管理的智能柜(智能管理系统),实现对载体的智能化、规范化、标准化管理,广泛应用于保密、机要单位以及企事业单位等有载体保管需求的行业。 随着信息化技术发展&…

基于 SpringBoot 的 “电影交流平台小程序” 系统的设计与实现

大家好,今天要和大家聊的是一款基于 SpringBoot 的 “电影交流平台小程序” 系统的设计与实现。项目源码以及部署相关事宜请联系我,文末附上联系方式。 项目简介 基于 SpringBoot 的 “电影交流平台小程序” 系统设计与实现的主要使用者分为 管理员 和…

【Rust中级教程】2.9. API设计原则之显然性(obvious) :文档与类型系统、语义化类型、使用“零大小”类型

喜欢的话别忘了点赞、收藏加关注哦(加关注即可阅读全文),对接下来的教程有兴趣的可以关注专栏。谢谢喵!(・ω・) 2.9.1. 文档与类型系统 用户可能不会完全理解API的所有规则和限制。所以你写的API应该让你…

【网络编程】广播和组播

数据包发送方式只有一个接受方,称为单播。如果同时发给局域网中的所有主机,称为广播。只有用户数据报(使用UDP协议)套接字才能广播: 广播地址以192.168.1.0 (255.255.255.0) 网段为例,最大的主机地址192.168.1.255代表该网段的广…

Lecture 1 - AI Systems (Overview)

一、Machine Learning Approach标准机器学习流程 • Train ML algorithm(训练机器学习算法):基于收集的数据训练机器学习模型。 二、Machine Learning for Adaptation(适应性机器学习) 加入了数据更新和自动化的部分…

Ansible 学习笔记

这里写自定义目录标题 基本架构文件结构安装查看版本 Ansible 配置相关文件主机清单写法 基本架构 Ansible 是基于Python实现的,默认使用22端口, 文件结构 安装 查看用什么语言写的用一下命令 查看版本 Ansible 配置相关文件 主机清单写法

springboot005学生心理咨询评估系统(源码+数据库+文档)

源码地址:学生心理咨询评估系统 文章目录 1.项目简介2.部分数据库结构与测试用例3.系统功能结构4.包含的文件列表(含论文)后台运行截图 1.项目简介 ​ 使用旧方法对学生心理咨询评估信息进行系统化管理已经不再让人们信赖了,把现…

Apache Doris:一款高性能的实时数据仓库

Apache Doris 是一款基于 MPP 架构的高性能、实时分析型数据库。它以高效、简单和统一的特性著称,能够在亚秒级的时间内返回海量数据的查询结果。Doris 既能支持高并发的点查询场景,也能支持高吞吐的复杂分析场景。 Apache Doris 最初是百度广告报表业务…

轻量级日志管理平台Grafana Loki

文章目录 轻量级日志管理平台Grafana Loki背景什么是Loki为什么使用 Grafana Loki?架构Log Storage Grafana部署使用基于 Docker Compose 安装 LokiMinIO K8s集群部署Loki采集Helm 部署方式和案例 参考 轻量级日志管理平台Grafana Loki 背景 在微服务以及云原生时…

《跟李沐学 AI》AlexNet论文逐段精读学习心得 | PyTorch 深度学习实战

前一篇文章,使用 AlexNet 实现图片分类 | PyTorch 深度学习实战 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started 本篇文章内容来自于学习 9年后重读深度学习奠基作之一:AlexNet【下】【论文精读】】的心得。 《跟李沐…

【电机控制器】FU6832S——持续更新

【电机控制器】FU6832S——持续更新 文章目录 [TOC](文章目录) 前言一、ADC二、UART三、PWM四、参考资料总结 前言 使用工具: 提示:以下是本篇文章正文内容,下面案例可供参考 一、ADC 二、UART 三、PWM 四、参考资料 总结 本文仅仅简…

计算机视觉算法实战——产品分拣(主页有源码)

✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连✨ ​ 1. 领域简介✨✨ 产品分拣是工业自动化和物流领域的核心技术,旨在通过机器视觉系统对传送带上的物品进行快速识别、定位和分类&a…

基于模块联邦的微前端架构:重构大型前端应用的模块化边界

引言:企业级前端的模块化困境 字节跳动广告系统采用Webpack 5模块联邦后,主应用构建时间从14分钟降至38秒,微应用独立发布频率提升至每天50次。在动态加载机制下,首屏资源加载体积减少79%,跨团队组件复用率达到92%。其…

Android之图片保存相册及分享图片

文章目录 前言一、效果图二、实现步骤1.引入依赖库2.二维码生成3.布局转图片保存或者分享 总结 前言 其实现在很多分享都是我们自定义的,更多的是在界面加了很多东西,然后把整个界面转成图片保存相册和分享,而且现在分享都不需要第三方&…

Linux放行端口

8080这个端口测试看telnet是不通的,您服务器内是否有对应的业务监听了这个端口呢?您到服务器内执行下: netstat -nltp |grep 8080 同时服务器内执行下: systemctl status firewalld iptables -nL 截图反馈下,我看下防火…

Spring Boot延迟执行实现

说明&#xff1a;本文介绍如何在Spring Boot项目中&#xff0c;延迟执行某方法&#xff0c;及讨论延迟执行方法的是事务问题。 搭建Demo 首先&#xff0c;创建一个Spring Boot项目&#xff0c;pom.xml如下&#xff1a; <?xml version"1.0" encoding"UTF-…

npm i 失败权限问题

安装完node之后, 测试全局安装一个最常用的 express 模块进行测试 失败&#xff0c;但是用管理员权限打开cmd 安装就成功。 报错如下&#xff1a; npm ERR! If you believe this might be a permissions issue, please double-check the npm ERR! permissions of the file and …

uniapp 微信小程序打包之后vendor.js 主包体积太大,解决办法,“subPackages“:true设置不生效

现在是打包的时候&#xff0c;vendor.js 的内容全部打到了主包里面&#xff0c; 说一下我的方法&#xff1a; 1. 通过发行 小程序打包 这样打包的体积是最小的&#xff0c;打包之后打开微信开发工具&#xff0c;然后再上传 2.manifest.json,在“mp-weixin”里添加代码 "…

23.2、云计算安全机制与案例分析

目录 云计算安全保护机制与技术方案云计算安全保护机制与技术方案常见云计算网络安全机制云计算安全管理与运维云计算安全综合应用案例分析 - 阿里云云计算安全综合应用案例分析 - 腾讯云云计算安全综合应用案例分析 - 华为云 云计算安全保护机制与技术方案 首先针对云计算&am…

游戏引擎学习第120天

仓库:https://gitee.com/mrxiao_com/2d_game_3 上次回顾&#xff1a;周期计数代码 我们正在进行一个项目的代码优化工作&#xff0c;目标是提高性能。当前正在优化某个特定的代码片段&#xff0c;已经将其执行周期减少到48个周期。为了实现这一目标&#xff0c;我们设计了一个…