百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

前端开发-Nginx了解一下

nanshan 2025-04-24 06:03 13 浏览 0 评论

为什么前端要学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;            # 零拷贝传输

需根据服务器硬件调整

相关推荐

MongoDB 从入门到实战:.NET 平台完整指南

一、什么是MongoDBMongoDB是一种功能强大且灵活的NoSQL数据库,适用于处理大规模的半结构化数据和高并发场景。它不依赖于固定的表结构和关系模型,而是以文档的形式存储数据,每个文档可...

NET Framework安装失败的原因及解决方法

大家好我是艾西,一个做服务器租用的游戏爱好者兼网络架构系统环境问题网络工具人。在我们平时使用PC安装某些程序会出现.NETFramework缺失的提示,那么也会有很多的小伙伴搞不懂什么原因导致的,这...

这可是全网eNSP安装最完整,最详细的图解,没有之一(常见问题)

eNSP安装大纲eNSP安装详细图解篇幅较长,会分三篇更完。急需安装的朋友可以在文末获取图解文档和所需软件工具。ENSP安装常见问题和解决方案Vbox安装错误eNSP在安装的过程当中,经常会出现一...

如何在windows 2012安装.NET Framework3.5

Windowsserver2012R2,自带的是.NETFramework4.5,如果想装SQLserver2008或者SQLserver2012需要安装.ENTFramework...

3款国内可用的「Chrome」扩展下载网站

身为程序员,有几个不使用Chrome浏览器提升下编码效率呢?Chrome拥有众多丰富强大的扩展程序,今天给大家分享三个国内可用的Chrome扩展下载网站,收藏一下吧,不然下次就找不到我咯!C...

下载 Windows 10 应用商店程序离线包方法

有厂商为了图方便,会把Windows10应用商店里面的UMP应用改成EXE程序版本。例如之前「网易云音乐」UMP版本简洁清爽,获得不少用户推荐,后来官方懒得更新了,直接把UMP版本...

极速安装!NET Framework 3.5零距离指南!

.NETFramework3.5是一款由微软开发的应用程序框架,它为许多Windows应用程序提供了基础支持。它的新版本带来了许多令人兴奋的功能和改进,比如增强的XML和JSON处理能力以及强大的...

Microsoft.NET离线运行库合集发布 2021

软件介绍.NET是微软具有战略意义的框架,也是装机必不可少的框架,想要一个一个安装略显繁琐,再加上很多电脑小白不知道怎么下载,不小心就下载到某某高速加载器,这个运行库极大解决了这个问题,采用微软官方....

缺少.net framework 3.5怎么办?(缺少.net4.5.1或以上环境)

很多电脑用户在玩某些程序游戏时都会遇到一个头痛的问题,弹出缺少“NETFramework3.5”的提示。微软从Windows8开始默认屏蔽了“.NET3.5”,如果用户有需要就必须选择在线安装...

Windows11无法正常安装.net 3.5组件的解决方法

最近因公司部分电脑升级至Windows11之后,重新安装某些需要加载.net3.5组件的应用软件时,都提示无法完成加载或安装.net3.5而导致无法完成安装。使用离线安装包亦一样无法完成安装。一...

离线安装.Net Framework 3.5(离线安装.net framework 4.0)

前言.Net3.5已经越来越少用到了,但是偶尔还是会遇到一些老软件需要。而Win10、Win11的系统,直接在控制面板的里添加,经常会添加失败!解决方法首先需要一个系统的ISO镜像来提取sxs文件夹:...

Jenkins 11个使用技巧,90%以上的人没用过

一、Performance插件兼容性问题自由风格项目中,有使用Performance插件收集构建产物,但是截至到目前最新版本(Jenkinsv2.298,Performance:v3.19),此...

6款Linux常用远程连接工具,你最中意哪一款?

点击上方头像关注我,每周上午09:00准时推送,每月不定期赠送技术书籍。本文2106字,阅读约需6分钟Hi,大家好。远程连接的实现方法有很多,概括地说有两种,一种是用系统自带的远程连接,另外一种是用...

Linux常用远程连接工具介绍,总有一款适合你

作为运维或者网工最常用就是ssh远程和远程桌面工具,本文就介绍几个常用的远程连接工具,你在用哪一款呢SecureCRT介绍:我觉得这个是最好的SSH工具,没有之一。SecureCRT支持SSH,同时支...

终极软路由网络设置,ESXi虚拟机安装iKuai+openWrt双路由系统

本内容来源于@什么值得买APP,观点仅代表作者本人|作者:BigBubbleGum本文是软路由系列的第五篇,也是折腾时间最长的一篇,在ESXi下分别独立安装和使用iKuai和openWrt...

取消回复欢迎 发表评论: