当前位置: 首页 > article >正文

Nginx location匹配模式详解

以下是对 Nginx location 匹配模式的详细说明及代码示例,包含注释解析:


1. 精确匹配(Exact Match)

语法: location = /path { ... }
优先级: 最高,仅当请求路径与 /path 完全一致时触发。

location = /login {# 仅匹配 `/login` 路径(区分大小写)# 例如:https://example.com/loginproxy_pass http://backend/login;
}

2. 前缀匹配(Prefix Match)

普通前缀匹配

语法: location /prefix { ... }
优先级: ,按配置文件顺序匹配,但可能被正则匹配覆盖。

location /static/ {# 匹配以 `/static/` 开头的路径,如 `/static/css/style.css`# 但如果没有 `^~` 修饰符,可能被后续正则匹配覆盖root /var/www/html;
}
优先前缀匹配

语法: location ^~ /prefix { ... }
优先级: 中高,匹配以 /prefix 开头的路径,且不再检查后续正则匹配

location ^~ /images/ {# 匹配以 `/images/` 开头的路径,如 `/images/logo.png`# 即使后续有正则匹配 `/images/.*\.png`,此配置仍优先root /data;
}

3. 正则匹配(Regular Expression Match)

区分大小写的正则

语法: location ~ /regex/ { ... }
优先级: ,按正则出现的顺序匹配,第一个匹配成功的生效。

location ~ \.php$ {# 匹配以 `.php` 结尾的路径(区分大小写),如 `/index.php`# 不会匹配 `/index.PHP`fastcgi_pass php:9000;
}
不区分大小写的正则

语法: location ~* /regex/ { ... }
优先级: ,同上,但忽略大小写。

location ~* \.(jpg|png|gif)$ {# 匹配 `.jpg`, `.png`, `.gif` 结尾的路径,不区分大小写# 如 `/image.JPG` 或 `/image.jpg`expires 30d;
}

4. 最长前缀匹配(Longest Prefix Match)

语法: location /longest/possible/path { ... }
优先级: ,当无精确或正则匹配时,选择最长前缀路径。

location /documents/ {# 匹配 `/documents/` 开头的路径,如 `/documents/report.pdf`root /var/data;
}location /documents/reports/ {# 更长的前缀,如 `/documents/reports/2023.pdf`root /var/special-data;
}

优先级总结

优先级从高到低排序:

  1. 精确匹配 (location = /path)
  2. 优先前缀匹配 (location ^~ /prefix)
  3. 正则匹配 (location ~ /regex/location ~* /regex/)
  4. 普通前缀匹配 (location /path)

完整示例配置

server {listen 80;server_name example.com;# 1. 精确匹配(最高优先级)location = /logo.png {root /var/www/exact;}# 2. 优先前缀匹配(次高优先级)location ^~ /static/ {root /var/www/static;}# 3. 正则匹配(区分大小写)location ~ /user/\d+ {proxy_pass http://user_backend;}# 4. 正则匹配(不区分大小写)location ~* \.(js|css)$ {root /var/www/assets;}# 5. 普通前缀匹配(最低优先级)location / {root /var/www/default;}
}

匹配过程解析

  1. 请求 /logo.png → 命中 location = /logo.png(精确匹配)。
  2. 请求 /static/css/style.css → 命中 location ^~ /static/(优先前缀匹配)。
  3. 请求 /user/123 → 命中 location ~ /user/\d+(正则匹配)。
  4. 请求 /IMAGE.JPG → 命中 location ~* \.(js|css)$(不区分大小写的正则匹配)。
  5. 请求 /about → 命中 location /(普通前缀匹配)。

调试技巧

  • 使用 nginx -T 查看完整配置。
  • 通过 error_log logs/error.log debug; 启用调试日志。
  • 在线工具测试正则:Nginx Location Tester。

通过理解这些规则,可以更精准地控制 Nginx 的路由逻辑!

相关文章:

Nginx location匹配模式详解

以下是对 Nginx location 匹配模式的详细说明及代码示例,包含注释解析: 1. 精确匹配(Exact Match) 语法: location /path { ... } 优先级: 最高,仅当请求路径与 /path 完全一致时触发。 location /login {# 仅匹配…...

Vue 3 路由传参使用指南

目录 一、路由传参概述 二、动态路由参数(params) 2.1 基础用法 2.2 传递参数 2.3 获取参数 2.4 可选参数 2.5 多个参数与正则约束 2.6 多 params 的详细用法 多个可选参数的使用 路由配置 获取可选参数 三、查询参数(Query&#x…...

vscode使用ssh链接服务器

vscode SSH vscode先下载remote ssh的插件,随后在左边的菜单栏里选择远程。 点击新建连接,输入用户名和地址,-p参数指定端口 ssh ubuntu{ip} -p xxx 随后就可以正常连接了,这里使用普通用户的用户名密码,别用root。 配…...

企业批量处理刚需PrintPDF 网络财务办公打印 网页到 Office 一键转 PDF

各位软件小达人,咱今天来唠唠PrintPDF。你知道吗,这玩意儿在好多软件和工具里都有,主要干这俩事儿。 先说说发票打印辅助工具。这东西可牛啦,它能专门快速打印发票、送货单这些票据。还能自己设定纸张大小,像A5、140…...

Python学习笔记--Django 表单处理

注意:本笔记基于python 3.12,django 5版本,不同版本使用上有些许差别。 HTML表单是网站交互性的经典方式。下面介绍如何用Django对用户提交的表单数据进行处理。 HTTP 请求 HTTP协议以"请求-回复"的方式工作。客户发送请求时&am…...

Python - 文件部分

- 第 101 篇 - Date: 2025 - 05 - 26 Author: 郑龙浩/仟墨 Python - 文件部分 学习时间: 2025-05-19 文章目录 Python - 文件部分一 文件与路径1 文本文件2 二进制文件3 编码格式① 常见编码格式② 指定编码格式③ 最佳格式④ 处理编码错误 4 绝对路径5 相对路径基本写法返回…...

【监控】Blackbox Exporter 黑盒监控

Blackbox Exporter 是 Prometheus 生态系统中的一个重要组件,用于执行 黑盒监控(Blackbox Monitoring)。与传统监控直接访问系统内部指标不同,黑盒监控通过向目标服务发送请求并分析响应,来评估服务的可用性、性能和功…...

历年福州大学保研上机真题

2025福州大学保研上机真题 2024福州大学保研上机真题 2023福州大学保研上机真题 在线测评链接:https://pgcode.cn/problem?classification1 螺旋矩阵 题目描述 给定一个整数 n n n,要求打印出一个 n n n \times n nn 的螺旋矩阵。 例如&#xff…...

【RAG】ragflow源码亮点:文档embedding向量化加权融合

引言: 最近在看ragflow源码,其中有一个较为巧妙地设计:分别将 文字 、 标题 行向量化 之后,直接根据权重,进行加法运算,得到向量融合,增强了文本向量化的表示能力,这里开始讨论一下…...

大模型学习笔记day2 LoRA微调

LORA的核心思想基准模型不进行变化,我额外引入一部分参数来做专属内容处理,同时加上原有模型的推理能力,这部分新增加的的内容就是要训练出来的参数矩阵。 本征维度(Intrinsic Dimension):是指数据或空间中…...

Maven-概述-介绍安装

目录 1.项目对象模型 2.依赖管理模型 3.仓库:用于存储资源,管理各种jar包 4.本地仓库路径 5.Maven配置本地仓库 5.1在Maven路径下新建文件夹用于本地仓库存储 5.2 复制本地仓库路径 5.3 找到配置文件路径,使用VSCode方式打开 5.4 新…...

GitHub Page填写域名显示被占用

问题描述 在Github上使用github page搭建个人博客,在项目中的Settings->Pages页面里面填写个人的域名时,出现如下报错信息,显示域名被占用情况 The custom domain example.com is already taken. If you are the owner of this domain, c…...

js实现监听Ctrl/Cmd+C复制、Ctrl/Cmd+Z撤销 等快捷键

使用document.addEventListener监听keydown事件即可: 上代码: document.addEventListener(keydown, function(e) {// 判断是否按下 Ctrl/Cmd Zif ((e.ctrlKey || e.metaKey) && e.key z && !e.shiftKey) {e.preventDefault(); // 阻…...

java高级 -动态代理

动态代理的概念 动态代理是一种在运行时生成代理对象的机制,无需手动编写代理类。 代理就类似于中介公司,为明星置办各种前期准备。例如歌声需要开演唱会唱歌,那么此时就需要代理对象进行置办场地,设备,然后明星只需要…...

机器学习算法:线性回归

1. 基础概念 线性回归是一种用于建模连续型目标变量(如价格、销量、温度)与一个或多个特征变量(如面积、广告投入、时间)之间线性关系的统计方法。 核心思想:找到一条直线(或超平面)&#xff0…...

NotePad++编辑Linux服务器文档

参考资料: 参考文章 相关插件链接:链接: https://pan.baidu.com/s/1PBX9NY0pPz0sBqtfNxngXA 提取码: r3t7 概要: 通常简单的文件编辑,可以直接在Linux服务器,或客户端利用VIM命令编辑,编辑即可 但是过于复杂的文件,比如Mycat的XML编辑,就很不方便,需要利用Notepad++…...

常见小问题(Open Folder as PyCharm Project)

1.删除pycharm鼠标右键快捷键打开项目 winr键打开,输入regedit,运行注册器 找到下面的路径:计算机\HKEY_CLASSES_ROOT\Directory\Background\shell\PyCharm 删除即可...

第四十四节:目标检测与跟踪-模板匹配

一、引言 模板匹配的核心思想是通过在输入图像中搜索与预定义模板最相似的区域来定位目标。这种方法计算效率高、实现简单,特别适用于目标外观变化不大且背景相对简单的场景。本文将深入探讨模板匹配的原理、OpenCV中的实现方法、优化技巧以及实际应用案例。 二、模板匹配基础…...

Trae中使用mcp连接MariaDB

开启mariadb远程权限 -- 登录 MariaDB(如果需要密码,会提示输入) mysql -u root -p -- 切换到权限管理数据库 USE mysql; -- 创建允许从任何 IP 访问的 root 用户(推荐使用强密码) GRANT ALL PRIVILEGES ON *.* …...

第12次04 :首页展示用户名

登录后&#xff0c;跳转到首页&#xff0c;首页会展示用户名&#xff1b;未登录时&#xff0c;首页将展示登录与注册的选项。 第一步&#xff1a;index.html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml…...

MFC: 文件加解密(单元测试模块)

背景&#xff1a; 对敏感配置文件&#xff08;如 XML 格式的配置文件、用户信息等&#xff09;进行加密&#xff0c;防止被人以文本形式直接查看。软件启动前加载加密的配置或资源文件&#xff0c;运行时再进行解密使用&#xff0c;提高逆向破解门槛。在传输 XML 文件&#xf…...

vue+ThreeJs 创建过渡圆圈效果

嗨&#xff0c;我是小路。今天主要和大家分享的主题是“vueThreeJs 创建过渡圆圈效果”。 今天在做着色器过渡效果练习&#xff0c;发现出现了很多新的函数&#xff0c;这些都超出了js之外&#xff0c;需要更多的掌握和学习。以下是自己的复盘和梳理。 1.获取距离 定…...

MySQL:12_视图

视图 跟事务里讲的视图没有任何关系 视图是一个虚拟表&#xff0c;其内容由查询定义。同真实的表一样&#xff0c;视图包含一系列带有名称的列和行数据。视图的数据变化会影响到基表&#xff0c;基表的数据变化也会影响到视图。 一.基本使用 创建视图 create view 视图名 …...

2025 年开源 LLM 发展趋势细致解读

1. 模型性能的持续跃进与架构创新 到 2025 年&#xff0c;开源 LLM 在性能上不仅持续追赶&#xff0c;甚至在特定任务和评估基准上已经能够与顶级的闭源模型并驾齐驱或展现出独特优势。MoE (Mixture of Experts) 架构的成熟和广泛应用是这一趋势中的核心驱动力之一。 MoE (Mix…...

win11+vs2022 安装opencv 4.11.0图解教程

1. 下载opencv opencv官网下载地址&#xff1a;Releases - OpenCV 2. 双击运行该exe&#xff0c;即可进行安装&#xff0c;安装文件夹可自行选择 安装后目录如下&#xff1a; 3. 配置环境变量 使用win键搜索环境变量&#xff0c;选中系统变量中的Path&#xff0c;然后点击编辑…...

n8n 读写本地文件

1.Docker Desktop 创建容器 docker run -d --name n8n -p 5566:5678 -v D:\docker\n8n_data:/home/node/.n8n -v D:\docker\n8n_files:/home/node/Files n8nio/n8n:latest 参数说明: 1.-d :表示以 detached 模式运行容器(后台运行) 2.--name n8n :指定容器名称为n8n。 3.-p 55…...

详解3DGS

4 可微分的3D高斯 splatting 核心目标与表示选择 我们的目标是从无法线的稀疏SfM点出发&#xff0c;优化出一种能够实现高质量新视角合成的场景表示。为此&#xff0c;我们选择3D高斯作为基本图元&#xff0c;它兼具可微分的体表示特性和非结构化的显式表示优势&#xff0c;既…...

DEBUG设置为False 时,django默认的后台样式等静态文件丢失的问题

1. 处理静态文件&#xff08;解决后台样式丢失&#xff09; 当 DEBUG False 时&#xff0c;Django 不再自动处理静态文件&#xff08;CSS、JS 等&#xff09;&#xff0c;需手动配置&#xff1a; 步骤&#xff1a; 配置 STATIC_ROOT 和 STATIC_URL 在 settings.py 中确保以下…...

如何提高服务器的QPS来应对618活动的并发流量

在电商行业&#xff0c;618大促是继双十一之后最重要的一次“流量大战”。大量用户在短时间内涌入网站下单、抢购&#xff0c;服务器面临前所未有的并发压力。QPS(Queries Per Second&#xff0c;即每秒请求数)作为衡量服务器处理能力的重要指标&#xff0c;直接关系到用户体验…...

LlamaFirewall:开源框架助力检测与缓解AI核心安全风险

LlamaFirewall 是一款面向大语言模型&#xff08;LLM&#xff09;应用的系统级安全框架&#xff0c;采用模块化设计支持分层自适应防御。该框架旨在缓解各类AI代理安全风险&#xff0c;包括越狱攻击&#xff08;jailbreaking&#xff09;、间接提示注入&#xff08;indirect pr…...