Nginx系列05(负载均衡、动静分离)

ops/2025/3/4 3:28:35/

目录

Nginx 负载均衡

Nginx 动静分离


Nginx 负载均衡

  • 概念:负载均衡是一种将网络流量分摊到多个后端服务器(节点)上的技术,以提高系统的可用性、性能和可扩展性。通过负载均衡,Nginx 可以根据一定的算法将客户端请求分发到不同的后端服务器,避免单个服务器因负载过高而出现性能瓶颈。
  • 原理:Nginx 通过upstream模块定义一组后端服务器,然后在server块或location块中使用proxy_pass指令将请求代理到upstream定义的服务器组。Nginx 支持多种负载均衡算法,常见的有:
    • 轮询(round - robin):依次将请求分配到后端服务器,每个服务器被选中的机会均等。
    • 加权轮询(weighted round - robin):根据服务器的性能或负载能力,为每个服务器分配一个权重,权重越大的服务器被选中的概率越高。
    • IP 哈希(ip - hash):根据客户端的 IP 地址计算一个哈希值,然后根据哈希值将请求分配到特定的服务器,这样可以确保同一客户端的请求始终被路由到同一台服务器,适用于需要保持会话一致性的场景。
  • 场景示例:假设有 3 台后端 Web 服务器,IP 地址分别为192.168.1.100192.168.1.101192.168.1.102,运行的端口都是8080,通过 Nginx 进行负载均衡配置如下:
http {upstream backend_servers {# 使用轮询算法,默认不写算法就是轮询server 192.168.1.100:8080; server 192.168.1.101:8080; server 192.168.1.102:8080; }server {listen 80;server_name example.com;location / {proxy_pass http://backend_servers; # 将请求代理到upstream定义的后端服务器组proxy_set_header Host $host; # 将客户端请求中的Host头信息传递给后端服务器proxy_set_header X-Real-IP $remote_addr; # 将客户端的真实IP地址传递给后端服务器proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 记录客户端的真实IP地址,当存在多个代理时,这个头信息会包含多个IP地址proxy_set_header X-Forwarded-Proto $scheme; # 将客户端请求的协议(http或https)传递给后端服务器}}
}

在这个配置中,upstream backend_servers定义了一个名为backend_servers的后端服务器组,包含 3 台服务器。server块中的location /配置将所有请求通过proxy_pass代理到backend_servers服务器组,Nginx 会按照轮询算法将请求依次分发到 3 台后端服务器上。

Nginx 动静分离

  • 概念:动静分离是指将网站的静态资源(如图片、CSS、JavaScript 文件等)和动态资源(如 PHP、JSP 生成的页面,需要服务器动态计算和处理的内容)分开处理和存储。这样可以提高网站的性能和可维护性,因为静态资源可以被缓存,减少服务器的计算压力,而动态资源可以由专门的应用服务器处理。
  • 原理:Nginx 通过配置不同的location块来分别处理静态资源和动态资源请求。对于静态资源请求,Nginx 可以直接从本地文件系统读取并返回,同时可以配置缓存策略来提高访问速度;对于动态资源请求,Nginx 通过proxy_pass将请求转发到后端的应用服务器(如 Tomcat、PHP - FPM 等)进行处理。
  • 场景示例:假设网站的静态资源存放在/var/www/html/static目录,动态资源由运行在127.0.0.1:8080的 Tomcat 服务器处理,配置如下:
http {server {listen 80;server_name example.com;# 处理静态资源请求location /static/ {root /var/www/html; # 静态资源的根目录,结合前面的location路径,实际访问的是/var/www/html/static目录下的文件expires 30d; # 设置静态资源的缓存过期时间为30天,浏览器在30天内再次请求相同资源时,直接从本地缓存读取,减少服务器压力access_log off; # 关闭静态资源的访问日志记录,减少日志文件大小}# 处理动态资源请求location / {proxy_pass http://127.0.0.1:8080; # 将请求转发到后端的Tomcat服务器proxy_set_header Host $host; # 将客户端请求中的Host头信息传递给后端服务器proxy_set_header X-Real-IP $remote_addr; # 将客户端的真实IP地址传递给后端服务器proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 记录客户端的真实IP地址,当存在多个代理时,这个头信息会包含多个IP地址proxy_set_header X-Forwarded-Proto $scheme; # 将客户端请求的协议(http或https)传递给后端服务器}}
}

在这个配置中,当客户端请求以/static/开头的资源时,Nginx 会直接从/var/www/html/static目录下读取文件并返回,同时设置了缓存过期时间和关闭访问日志。当客户端请求其他资源时,Nginx 会将请求转发到127.0.0.1:8080的 Tomcat 服务器进行处理。


http://www.ppmy.cn/ops/162940.html

相关文章

基于SpringBoot+Vue的医院挂号管理系统+LW示例参考

系列文章目录 1.基于SSM的洗衣房管理系统原生微信小程序LW参考示例 2.基于SpringBoot的宠物摄影网站管理系统LW参考示例 3.基于SpringBootVue的企业人事管理系统LW参考示例 4.基于SSM的高校实验室管理系统LW参考示例 5.基于SpringBoot的二手数码回收系统原生微信小程序LW参考示…

React 高阶组件(HOC)

1.React 高阶组件(HOC) ****1. HOC(高阶组件)HOC (Higher - Order Component) 定义: 高阶组件是一个接收组件作为参数并返回新组件的函数,用于复用组件逻辑,遵循纯函数特性(无副作用…

Composer如何通过GitHub Personal Access Token安装私有包:完整教程

使用Composer安全管理您的PHP私有依赖包 一、前言 在PHP开发中,我们经常需要将内部工具包托管为私有仓库。传统的账号密码验证方式存在安全隐患,而GitHub Personal Access Token(PAT)提供了一种更安全的鉴权方案。本文将通过4个…

【欢迎来到Git世界】Github入门

241227 241227 241227 Hello World 参考:Hello World - GitHub 文档. 1.创建存储库 r e p o s i t o r y repository repository(含README.md) 仓库名需与用户名一致。 选择公共。 选择使用Readme初始化此仓库。 2.何时用分支&#xf…

Saleae逻辑分析仪的安装与使用

Saleae逻辑分析仪的安装与使用 软件下载与安装 官网地址: www.saleae.com 在我的电脑上打不开这个网站, 显示无法访问此页面. 但用户也可以打开这个网站 Download | Saleae Support 然而点击下载按钮, 将会跳转到之前打不开的网站 解决电脑打不开Saleae官网 尝试方法 手机…

存贮论模型案例与Matlab实现

摘要:本文结合存贮论确定性模型,详细解析经济订购批量(EOQ)、允许缺货生产批量等核心模型,并通过商品库存管理、生产计划等实际案例,配合Matlab代码实现,展示模型求解过程。涵盖公式推导、参数优…

Ubuntu 下 nginx-1.24.0 源码分析 - ngx_init_cycle 函数 - 详解(3)

详解(3) 初始化路径数组(paths) n old_cycle->paths.nelts ? old_cycle->paths.nelts : 10;if (ngx_array_init(&cycle->paths, pool, n, sizeof(ngx_path_t *))! NGX_OK){ngx_destroy_pool(pool);return NULL;}ng…

一文掌握模拟登录的基本原理和实战

文章目录 1. 模拟登录的基本原理1.1 登录流程1.2 关键技术2. 模拟登录的实战步骤2.1 分析登录页面2.2 使用 Requests 实现模拟登录2.3 处理验证码2.4 使用 Selenium 实现模拟登录3. 实战案例:模拟登录豆瓣3.1 分析豆瓣登录页面3.2 实现代码4. 注意事项5. 总结模拟登录是爬虫开…