Nginx在前后端分离中的作用以及对比

 更新时间:2026年05月22日 08:53:34   作者:bug攻城狮  
文章对比了直接访问(不使用Nginx)与使用Nginx(反向代理)两种方式的特点、优势及应用场景,直接访问简单直接但安全性较低;Nginx增加中间层代理,解决跨域、负载均衡等问题,适合生产环境,建议小型项目直接访问,大项目应推荐使用Nginx以获得更好的性能和安全性

1. 不使用Nginx(直接访问)

前端(Vue) → 直接请求 → Spring Boot后端

特点:

  • 简单直接:开发阶段方便调试
  • 端口 暴露:后端端口直接对外暴露(如8080)
  • 跨域问题:需要后端配置CORS解决跨域
  • 无负载均衡:只能连接单一后端实例
  • 静态资源服务:Spring Boot需要自己服务静态资源(如配置WebMvc)
  • 安全性:缺少额外的安全层保护

2. 使用Nginx(反向代理)

前端(Vue) → Nginx → Spring Boot后端
	↑	 ↑
静态资源		反向代理

主要区别和优势:

维度不使用Nginx使用Nginx
架构前后端直接通信增加中间层代理
跨域处理需后端配置CORSNginx代理自动解决跨域
负载均衡不支持支持多实例负载均衡
静态资源需单独配置或CDNNginx高性能静态服务
性能后端直接处理所有请求静态资源由Nginx处理,减少后端压力
安全性较低隐藏后端端口、防DDoS、限流等
SSL/HTTPS需Spring Boot配置Nginx统一管理SSL证书
部署灵活性灵活性低前后端分离更彻底

3. 典型应用场景对比

场景A:开发环境(常不使用Nginx)

// vue.config.js
devServer: {
	proxy: {
		'/api': {
			target: 'http://localhost:8080', // 直接连Spring Boot
			changeOrigin: true
		}
	}
}

场景B:生产环境(推荐使用Nginx)

# nginx.conf
server {
	listen 80;
	server_name example.com;
	
	# 1. 服务Vue静态文件
	location / {
		root /var/www/vue-app;
		index index.html;
		try_files $uri $uri/ /index.html; # 支持Vue Router history模式
	}
	
	# 2. 反向代理API请求
	location /api/ {
		proxy_pass http://backend-server:8080/;
		proxy_set_header Host $host;
		proxy_set_header X-Real-IP $remote_addr;
		proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
		
		# 跨域配置
		add_header Access-Control-Allow-Origin *;
		add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
		add_header Access-Control-Allow-Headers 'DNT,User-Agent,X-Requested-With,Content-Type';
		
		# 缓存配置
		proxy_cache my_cache;
		proxy_cache_valid 200 302 10m;
	}
	
	# 3. 负载均衡配置
	upstream backend-server {
		server 192.168.1.101:8080 weight=3; # 权重负载
		server 192.168.1.102:8080 weight=2;
		server 192.168.1.103:8080 backup;# 备用服务器
	}
	
	# 4. 性能优化
	gzip on;# 开启压缩
	gzip_types text/plain application/javascript application/json;
}

4. 具体差异示例

差异1:跨域处理

# Nginx解决跨域(无需修改后端代码)
location /api/ {
	proxy_pass http://localhost:8080/api/;
	add_header Access-Control-Allow-Origin $http_origin always;
	add_header Access-Control-Allow-Credentials true always;
	add_header Access-Control-Allow-Methods 'GET,POST,PUT,DELETE,OPTIONS' always;
	
	# 处理OPTIONS预检请求
	if ($request_method = 'OPTIONS') {
		return 204;
	}
}

差异2:静态资源服务

# Nginx高效服务静态资源(优于Spring Boot)
location /static/ {
	root /var/www/vue-app;
	expires 30d;# 缓存30天
	access_log off;
	
	# 启用gzip压缩
	gzip_static on;
}

差异3:安全加固

# 安全配置(Nginx层面)
server {
	# 隐藏服务器信息
	server_tokens off;
	
	# 限制请求大小
	client_max_body_size 10m;
	
	# 限流
	limit_req_zone $binary_remote_addr zone=api:10m rate=10r/s;
	
	location /api/ {
	limit_req zone=api burst=20 nodelay;
		proxy_pass http://backend:8080;
	}
}

5. 建议方案

开发环境:

  • 直接连接:Vue devServer代理到Spring Boot
  • 简单快速,便于调试

生产环境(推荐使用Nginx):

  1. Nginx + Vue:服务静态文件
  2. Nginx → Spring Boot集群:反向代理API请求

优点

  • 前后端完全解耦
  • 高性能静态资源服务
  • 负载均衡和高可用
  • 统一的安全策略
  • 易于水平扩展

6. 性能对比数据

指标直接连接Nginx代理
静态资源QPS~1000~5000+
内存占用较低额外占用(约10-50MB)
并发连接数受Spring Boot限制Nginx高性能处理
响应时间直接增加约1-5ms延迟

总结建议

小型项目/原型阶段:可不使用Nginx,简化部署

中大型项目/生产环境:强烈推荐使用Nginx,获得:

  1. 更好的性能(静态资源服务)
  2. 更高的安全性
  3. 更强的扩展性(负载均衡)
  4. 更灵活的部署架构

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Nginx进行域名重写和泛域名解析配置的方法

    Nginx进行域名重写和泛域名解析配置的方法

    这篇文章主要介绍了Nginx进行域名重写和泛域名解析配置的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • Nginx启用Brotli算法压缩的示例

    Nginx启用Brotli算法压缩的示例

    这篇文章主要介绍了Nginx启用Brotli算法压缩的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • Nginx的proxy_pass命令使用

    Nginx的proxy_pass命令使用

    ,proxy_pass指令用于将请求转发到后端服务器,它可以用于 HTTP 和 Stream 模块,分别处理 HTTP 请求和 TCP/UDP 流量,下面就来详细介绍一下如何使用,感兴趣的可以了解一下
    2026-05-05
  • Ubuntu系统下安装与完全卸载Nginx的步骤

    Ubuntu系统下安装与完全卸载Nginx的步骤

    在Linux服务器上管理和部署Web服务,Nginx是一个常见的选择,因为它的高性能和稳定性,这篇文章主要介绍了Ubuntu系统下安装与完全卸载Nginx的相关资料,需要的朋友可以参考下
    2025-08-08
  • Nginx Rewrite使用场景及配置方法解析

    Nginx Rewrite使用场景及配置方法解析

    这篇文章主要介绍了Nginx Rewrite使用场景及配置方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • Nginx Proxy 代理测试的实现

    Nginx Proxy 代理测试的实现

    本文主要介绍了Nginx Proxy 代理测试的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-02-02
  • nginx.conf配置文件结构小结

    nginx.conf配置文件结构小结

    本文主要介绍了nginx.conf配置文件结构小结,nginx.conf主要由events、http、server、location、upstream等块配置项和一些行配置项组成,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • 详解nginx.conf 中 root 目录设置问题

    详解nginx.conf 中 root 目录设置问题

    这篇文章主要介绍了详解nginx.conf 中 root 目录设置问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • 分割nginx日志的实现(避免日志多大)

    分割nginx日志的实现(避免日志多大)

    nginx默认没有提供对日志文件的分割功能,所以随着时间的增长,access.log和error.log文件会越来越大,本文主要介绍了分割nginx日志的实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-04-04
  • Nginx隐藏式跳转(浏览器URL跳转后保持不变)

    Nginx隐藏式跳转(浏览器URL跳转后保持不变)

    这篇文章主要介绍了Nginx隐藏式跳转(浏览器URL跳转后保持不变),需要的朋友可以参考下
    2022-04-04

最新评论