前端开发-Nginx了解一下

createh52周前 (05-25)技术教程3

为什么前端要学Nginx?

Nginx是异步框架的网页服务器,也可以用作反向代理、负载平衡器和HTTP缓存。不知道各位同学在开发过程中有没有使用过Nginx。如果我们想玩一下个人服务器,起一个个人博客网站,Nginx是绕不过去的工具。Nginx对于前端开发,它主要解决三大痛点:

  1. 本地联调跨域:绕过浏览器同源限制,实现API代理转发
  2. 生产环境优化:压缩静态资源、开启缓存、实现CDN加速
  3. 高效部署工具:一键部署SPA应用,支持路由History模式

核心功能

1. 反向代理(API请求管家)

# 将/api请求转发到后端服务器
location /api {
  proxy_pass http://backend-server:8080;
  proxy_set_header Host $host;
  proxy_set_header X-Real-IP $remote_addr;
}

原理:浏览器→Nginx→后端服务,用户无感知服务器真实地址

2. 静态资源服务(性能加速器)

# 配置Gzip压缩
gzip on;
gzip_types text/css application/javascript;

# 设置缓存策略
location /static {
  root /var/www;
  expires 30d;
  add_header Cache-Control "public";
}

效果:1MB的JS文件压缩后仅300KB,缓存命中率提升80%

3. 负载均衡(流量调度员)

upstream backend {
  server 192.168.1.1:8080 weight=5;  # 权重分配
  server 192.168.1.2:8080;
  ip_hash;  # 同一IP固定访问某服务器
}

location / {
  proxy_pass http://backend;
}

支持策略:轮询、权重、IP哈希、最少连接数

4. HTTPS配置(安全门卫)

server {
  listen 443 ssl;
  ssl_certificate /path/to/cert.pem;
  ssl_certificate_key /path/to/key.pem;
  # 强制HTTP跳转HTTPS
  return 301 https://$host$request_uri;
}

通过Let's Encrypt免费证书,10分钟实现全站加密

前端项目实战指南

1. 本地开发环境搭建(解决跨域)

# 前端项目运行在localhost:3000,代理API到localhost:8080
server {
  listen 80;
  server_name local.dev;
  
  location / {
    proxy_pass http://localhost:3000;
  }

  location /api {
    proxy_pass http://localhost:8080;
  }
}

修改Hosts文件添加127.0.0.1 local.dev,访问local.dev即可

2. SPA路由配置(解决404问题)

location / {
  root /dist;
  try_files $uri $uri/ /index.html;
}

让Vue/React的路由History模式正常运作

3. 性能优化三板斧

  • 图片压缩:image_filter resize 800 600;
  • Brotli压缩:brotli on; brotli_types *;
  • HTTP2推送:http2_push /static/logo.png;

高频面试题精选

1.正向代理 vs 反向代理区别?

正向代理:客户端知道目标服务器(如VPN),隐藏客户端

反向代理:客户端不知道目标服务器,隐藏服务端

2.Nginx如何处理高并发?

采用事件驱动+非阻塞IO模型,单个进程可处理数万连接

3.location匹配优先级规则?
精确匹配
= > 正则 ~ > 前缀 ^~ > 普通前缀 > 通用 /

4.如何实现灰度发布

map $cookie_version $group {
  default "prod";
  "v2" "canary";
}
upstream canary { server 10.0.0.1; }
upstream prod { server 10.0.0.2; }
location / {
  proxy_pass http://$group;
}

5.Nginx性能优化参数?

worker_processes auto;  # CPU核心数
worker_connections 1024;单个进程最大连接数
keepalive_timeout 65;   # 长连接超时
sendfile on;            # 零拷贝传输

需根据服务器硬件调整

相关文章

NGINX 性能优化与高级配置:榨干服务器潜能,打造极致体验

NGINX 以其卓越的性能和高并发处理能力闻名于世,但默认配置往往只是一个普适性的起点。要想真正发挥 NGINX 的潜能,满足日益增长的业务需求,深入理解其配置并进行精细化调优至关重要。这就像拥有一辆...

高并发场景下,Nginx性能如何提升10倍?

大家好,我是mikechen。在高并发场景,Nginx 是流量入口的第一道防线,如果想拦截亿级流量,需要Nginx合理调优才能应对@mikechen。本文作者:陈睿|mikechen文章来源:mike...

Nginx缓存最全详解:如何提高10倍性能!

关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen睿哥。Nginx是大型架构的必备中间件,下面我就重点来详解Nginx缓存核心技术@mikechenNginx缓存Ng...

LVS、Nginx压测与性能调优(超详细)

LVS和Nginx作为一个常用的负载均衡软件,充当集群流量入口的角色,需要承载的业务流量一般都比较大,这个时候对LVS/Nginx节点进行一些参数调优,对于发挥它们的性能有很大的帮助。一、 可能会负载...

Nginx在高并发下的性能优化点!有这篇就够了

20大进阶架构专题每日送达前面几周,讲过Nginx的日志配置:Nginx | 超详细!Nginx 日志配置实践,然后也讲了Nginx的进程模型,底层原理等:Nginx为什么快到根本停不下来?没看过的可...

高并发场景下,如何提升Nginx并发性能?

Nginx是大型架构的必备中间件,也是高并发的核心组件,下面我就重点详解5大Nginx高并发优化方案@mikechen本文作者:mikechen文章来源:mikechen.ccNginx高并发Ngin...