nginx

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > nginx > Nginx在前后端分离中的作用对比

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

作者:bug攻城狮

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

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

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

特点:

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. 建议方案

开发环境:

生产环境(推荐使用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. 更灵活的部署架构

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

您可能感兴趣的文章:
阅读全文