网站首页 > 技术文章 正文
为什么前端要学Nginx?
Nginx是异步框架的网页服务器,也可以用作反向代理、负载平衡器和HTTP缓存。不知道各位同学在开发过程中有没有使用过Nginx。如果我们想玩一下个人服务器,起一个个人博客网站,Nginx是绕不过去的工具。Nginx对于前端开发,它主要解决三大痛点:
- 本地联调跨域:绕过浏览器同源限制,实现API代理转发
- 生产环境优化:压缩静态资源、开启缓存、实现CDN加速
- 高效部署工具:一键部署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; # 零拷贝传输
需根据服务器硬件调整
猜你喜欢
- 2025-04-27 前端开发必备之迭代语句
- 2025-04-27 小程序设计新手必看:5个实用技巧提升用户体验!
- 2025-04-27 Cursor 在前端需求开发工作流中的应用|得物技术
- 2025-04-27 前端开发-Vite新时代构建工具
- 2025-04-27 前端必看!10 个超实用 Vue3 实战技巧,助你成为开发大神
- 2025-04-27 从0开始学习element-ui开发-DAY3-前端API接口
- 2025-04-27 前端开发-SVG从入门到实战
- 2024-09-09 2021年全新升级的前端学习路线图
- 2024-09-09 前端开发技术集锦-三部曲
- 2024-09-09 百度Web前端开发实战案例解析
你 发表评论:
欢迎- 05-10如何优化数据库和前端之间的交互?
- 05-10前端代码优化小秘籍(前端优化24条建议)
- 05-10VS Code当中的15个神仙插件,值得收藏
- 05-10如何自己开发一个Google浏览器插件?
- 05-10前端流行框架Vue3教程:14. 组件传递Props效验
- 05-10吃了一年的SU,最好用的插件都在这了
- 05-10前端必看!这款神器让网站界面告别千篇一律
- 05-10程序员请收好:10个非常有用的 Visual Studio Code 插件
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle查询数据库 (45)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)