网站首页 > 技术文章 正文
为什么前端要学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前端开发实战案例解析
你 发表评论:
欢迎- 06-24发现一款开源宝藏级工作流低代码快速开发平台
- 06-24程序员危险了,这是一个 无代码平台+AI+code做项目的案例
- 06-24一款全新的工作流,低代码快速开发平台
- 06-24如何用好AI,改造自己的设计工作流?
- 06-24濮阳网站开发(濮阳网站建设)
- 06-24AI 如何重塑前端开发,我们该如何适应
- 06-24应届生靠这个Java简历模板拿下了5个offer
- 06-24服务端性能测试实战3-性能测试脚本开发
- 566℃Oracle分析函数之Lag和Lead()使用
- 566℃几个Oracle空值处理函数 oracle处理null值的函数
- 550℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 545℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 543℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 536℃【数据统计分析】详解Oracle分组函数之CUBE
- 526℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 519℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)