nginx conf配置

配置把“前端静态文件”和“后端接口”统一收在 同一个 server{} 里,通过 两条 location 做分流,其中 /api 这条 location 用到了一点“小技巧”把路径裁掉后再转发。下面按执行顺序逐句拆解,告诉你“请求是怎么被转发到 127.0.0.1:8081 的”。


  1. 全局上下文
worker_processes  1;          # 只启 1 个 worker 进程(单核开发机够用)
events { worker_connections 1024; }  # 每个 worker 同时维持 1024 条连接
http { … }                    # 下面所有指令都属于 http 层

  1. 监听端口与主机名
server {listen       8080;        # 浏览器访问 http://localhost:8080server_name  localhost;…
}

  1. 前端静态资源定位
location / {root   html/hmdp;         # 把 “/” 映射到 $NGINX_HOME/html/hmdpindex  index.html index.htm;
}
  • 请求 http://localhost:8080/ → nginx 在 html/hmdp/index.html 找文件并返回。
  • 所有 JS/CSS/图片只要路径不以 /api 开头,都走这条规则。

  1. 后端接口转发(核心)
location /api { … }

当 URI 以 /api 开头时,进入该上下文,下面每一步都决定了“如何转发”。

4.1 剥离前缀

rewrite /api(/.*) $1 break;
  • 正则把 /api/user/login 捕获成 /user/login 并存入 $1
  • break 表示不再重新搜索 location,在当前 location 内继续执行。
    结果:nginx 内部把 URI 改成 /user/login,但浏览器地址栏仍是 /api/user/login

4.2 设置代理协议版本

proxy_http_version 1.1;

开启 HTTP/1.1,才能使用长连接(keep-alive),减少反复握手。

4.3 打开请求头透传

proxy_pass_request_headers on;

默认就是 on,写在这里为了显式强调:浏览器发来的所有头(Cookie、Authorization…)都会原样送到后端。

4.4 指定上游地址

proxy_pass http://127.0.0.1:8081;
  • 把已经 rewrite 过的 /user/login 直接发给本机 8081 端口。
  • 如果这里写成 http://backend 就会走下面定义的 upstream 负载均衡,但作者注释掉了。

4.5 失败重试

proxy_next_upstream error timeout;

只有写 proxy_pass http://backend 且 upstream 里有多台机器时,这条才会触发“换下一台重试”。目前只有一台,写不写效果一样。

4.6 keep-alive 连接池

keepalive_timeout   30s;
keepalive_requests  1000;

告诉 nginx“与后端 8081 保持长连接,最多复用 1000 次或 30 s 超时再关闭”,减少 TCP 三次握手开销。


  1. upstream 块(备用)
upstream backend {server 127.0.0.1:8081 max_fails=5 fail_timeout=10s weight=1;
}
  • 目前只有一台,实际没用到。
  • 如果想水平扩容,再写一行 server 127.0.0.1:8082 …,然后把 proxy_pass http://127.0.0.1:8081 改成 proxy_pass http://backend 即可自动轮询+故障摘除。

  1. 错误页
error_page 500 502 503 504 /50x.html;
location = /50x.html { root html; }

后端 8081 挂掉或返回 50x 时,nginx 会把 html/50x.html 的内容返回给浏览器,避免裸错。


  1. 请求完整生命周期举例
    浏览器输入:
    http://localhost:8080/api/user/login

  2. nginx 监听 8080,收到 GET /api/user/login

  3. 匹配 location /api → 进入该上下文

  4. rewrite 把 URI 改成 /user/login

  5. proxy_pass http://127.0.0.1:8081 → 发请求 GET /user/login 给后端

  6. 后端返回 JSON → nginx 原样返给浏览器(因为 default_type application/json 只是响应头兜底,实际后端返回什么 Content-Type 就按什么走)


一句话总结
先 rewrite 去掉 /api 前缀,再用 proxy_pass 把剩余路径转发到 127.0.0.1:8081,同时开启 HTTP1.1 长连接和失败重试机制”——这就是该配置实现“前端请求转发给后端”的全部秘密。

不用在 IDEA 里把“127.0.0.1:8081”写死到代码里;

IDEA 只负责把 Spring Boot(或你用的框架)启动在 8081 端口即可,剩下的由 Nginx 来“敲门”。


  1. IDEA 侧该做什么
  • 保证项目 application.yml / application.properties 里端口是 8081:
    server:port: 8081
    
  • 直接点 ▶️ RunDebug,让服务在 8081 端口处于 LISTEN 状态。

  1. 验证端口是否已开启
# macOS / Linux
lsof -i:8081
# Windows
netstat -ano | findstr 8081

看到 LISTEN 就说明 IDEA 已经把后端程序跑起来了,Nginx 随时可以把 /api 请求转发过来。


  1. 什么时候才需要在 IDEA 里配“外部地址”
  • 本地调试前端页面,但想让前端直接调 IDEA 里的后端(不走 Nginx),
    才在前端 .envvite.config 里写:

    VITE_API_BASE = 'http://127.0.0.1:8081'
    

    这只是开发阶段的浏览器→后端直连,与 Nginx 无关。

  • 一旦用 Nginx 做反向代理,前端就统一访问 http://localhost:8080/api/...
    由 Nginx 转发到 IDEA 的 8081,代码/IDEA 侧无需再感知 127.0.0.1:8081


一句话总结
IDEA 只要把项目跑在 8081 端口就行,不需要也不推荐把“127.0.0.1:8081”硬编码到后端代码里;Nginx 自己会来“敲门”。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/96192.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/96192.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/96192.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HTML 各种标签的使用说明书

HTML 各种标签的使用说明书 1. HTML 简介 HTML(HyperText Markup Language,超文本标记语言)是用于创建网页的标准标记语言。它使用一系列标签来描述网页的结构和内容,这些标签被浏览器解释并渲染成用户看到的网页。HTML是构建We…

从关键词到语义理解:小陌引擎如何重构AI搜索优化逻辑?

引言:AI搜索时代的范式转变在传统互联网时代,SEO(搜索引擎优化)是企业数字营销的核心策略,通过关键词密度、外链建设等技术手段提升网页在搜索引擎结果页(SERP)中的排名。然而,随着生…

ADE explorer遇到XVFB服务器的问题

遇到这个报错,是因为服务器没有安装xvfb的原因。yum install Xvfb即可解决问题。

期权的套利怎么理解?

期权套利是利用期权价格之间的不合理偏差,通过构建对冲组合获取无风险利润的策略。其核心逻辑基于“无套利定价原则”——若存在价格偏差,市场力量会迅速修正,套利者通过反向操作锁定利润。期权的套利怎么理解?一、主要套利类型与…

RabbitMQ 重试机制 和 TTL

目录 1. 重试机制 1.1 简介 1.2 配置文件 1.3 消费者确认机制为 auto 时 1.4 消费者确认机制为 manual 时 2. TTL 2.1 设置消息的过期时间 2.2 设置队列的过期时间 2.3 给过期队列中消息设置过期时间 1. 重试机制 1.1 简介 在消息传递过程中, 可能会遇到各种问题, …

四、FVP启动linux

目录 1 实验目的及环境 1.1 实验目的 1.2 实验环境 1.2.1 拉取代码 1.2.2搭建交叉编译环境 2 相关镜像编译 2.1 TF-A镜像编译 2.2 U-Boot镜像编译 2.3 Linux Kernel镜像编译 2.4 构建跟文件系统 3 启动linux内核 3.1 启动脚本构建 3.2 启动Linux内核 1 实验目的及环境 1.1 实验…

浅聊一下微服务的服务保护

在微服务架构里,服务间调用关系错综复杂,一个服务出问题很可能引发连锁反应,也就是 “雪崩”。今天就带大家从零开始学习 Sentinel,这款阿里开源的微服务保护工具,帮你解决雪崩难题,做好流量控制、隔离降级…

ECharts Gallery:Apache官方数据可视化模板库,助你快速制作交互图表并实现深度定制

你有没有过这种时候?手里攥着一堆 Excel 数据,想做个直观的图表给同事看,用 Excel 自带的图表吧,样式丑不说,稍微复杂点的交互(比如点击柱子显示详情)根本做不了;想自己用代码写吧&a…

[数据结构——lesson3.单链表]

目录 引言 学习目标: 1.什么是链表 2.链表的分类 2.1 单向链表和双向链表 (1)单向链表 (2)双向链表 2.2 带头结点链表和不带头结点链表 (1)带头结点链表 (2)不带头结点链表 2.3 循环链表和不循环链表 (1)循环链表 (2)非循环链表 3.链表的实…

从零深入理解嵌入式OTA升级:Bootloader、IAP与升级流程全解析

引言(Opening)想象一下,你开发的一款智能水杯、一个环境监测设备或者一台共享充电宝,已经部署到了成千上万的用户手中。突然,你发现了一个软件bug,或者需要增加一个酷炫的新功能。你不可能派人跑到每个设备…

【Ansible】实施 Ansible Playbook知识点

1.清单概念与静态清单文件是什么?答:Ansible 清单是被管理主机的列表,用于明确Ansible的管理范围,分为静态清单和动态清单。静态清单是通过手动编辑的文本文件来定义被管主机,文件格式可以是INI格式或YAML格式。在INI格…

【Linux】vim工具篇

目录一、vim的多模式1.1 命令模式1.1.1 光标移动1.1.2 复制及撤销1.1.3 剪切及删除1.1.4 替换1.1.5 批量化注释/去注释1.2 底行模式二、vim的配置个人主页<—请点击 Linux专栏<—请点击 一、vim的多模式 vim是一款功能强大的文本编辑器&#xff0c;它编辑代码主要围绕命…

Spark 核心原理:RDD, DataFrame, DataSet 的深度解析

Apache Spark 是一个强大的分布式计算系统&#xff0c;以其内存计算、速度快、易用性强等特点&#xff0c;在大数据处理领域占据重要地位。理解 Spark 的核心原理&#xff0c;特别是其三种核心抽象——RDD, DataFrame, DataSet——对于高效地使用 Spark 至关重要。本文将深入解…

Docker 命令行的使用

1.Docker 命令列表[roothost1 ~]# docker Usage: docker [OPTIONS] COMMANDA self-sufficient runtime for containersCommon Commands:run Create and run a new container from an imageexec Execute a command in a running containerps List cont…

Redis Stream:轻量级消息队列深度解析

&#x1f4e8; Redis Stream&#xff1a;轻量级消息队列深度解析 文章目录&#x1f4e8; Redis Stream&#xff1a;轻量级消息队列深度解析&#x1f9e0; 一、Stream 数据结构解析&#x1f4a1; Stream 核心概念&#x1f4cb; Stream 底层结构⚡ 二、消息生产与消费&#x1f68…

Android studio的adb和终端的adb互相抢占端口

在Android Studio调试时&#xff0c;有时候也需要借助终端的adb命令&#xff0c;他们互相抢占端 口&#xff0c;导致调试麻烦解决如下&#xff1a;① 终端adb的版本是&#xff1a;1.0.39路径是:/usr/lib/android-sdk/platform-tools/adb② Android Studio使用的adb来源于Androi…

GEO服务商推荐:移山科技以划时代高精尖技术引领AI搜索优化新纪元

引言&#xff1a;AI搜索生态重塑与GEO优化战略地位跃升AI技术对信息检索范式的颠覆GEO优化在企业增长中的核心作用第一章&#xff1a;AI搜索新纪元的企业营销挑战与机遇生成式AI成为用户主要信息入口的行业趋势企业在AI搜索中的“答案主权”争夺战GEO优化服务商的核心能力模型&…

Android SystemServer 系列专题【AttentionManagerService】

AttentionManagerService是framework中用来实现屏幕感知的一个系统级服务&#xff0c;他继承于systemserver。我们可以通过dumpsys attention来获取他的一些信息。如下针对屏幕感知的功能的引入来针对这个服务进行一个介绍。1、屏幕感知Settings UI实现屏幕感知的功能在A14上面…

nginx 反向代理使用变量的坑

nginx采用反向代理的时候使用变量的坑 正常情况&#xff1a; location ~ ^/prod-api(?<rest>/.*)?$ {# 假设 $mes_backend 形如: http://127.0.0.1:16889proxy_pass $mes_backend$rest$is_args$args;proxy_http_version 1.1;proxy_set_header Host $host;…

Origin绘制径向条形图|科研论文图表教程

数据排列格式截图&#xff0c;请查看每张图↘右下角水印 目录 数据排列格式截图&#xff0c;请查看每张图↘右下角水印 本 期 导 读 No.1 理解图形 1 定义 2 特点 3 适用场景 No.2 画图教程 1 导入数据&#xff0c;绘制图形 2 设置绘图细节 本 期 导 读 径…