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

【服务器知识】Nginx路由匹配规则说明

Nginx路由匹配规则说明

      • **一、Nginx路由匹配核心机制**
      • **二、匹配规则语法详解**
        • 1. **精确匹配 (`=`)**
        • 2. **前缀匹配 (`^~` 或 `/`)**
        • 3. **正则匹配 (`~` 或 `~*`)**
        • 4. **通配符匹配 (`*`)**
      • **三、路由匹配优先级顺序**
      • **四、高级路由技巧**
        • 1. **条件判断 (`if`语句)**
        • 2. **路径重写 (`rewrite`指令)**
        • 3. **负载均衡路由**
      • **五、实战案例:多版本API路由**
        • **需求**:
        • **配置**:
      • **六、常见陷阱与调试**
        • 1. **优先级错误**
        • 2. **正则表达式性能**
        • 3. **日志调试**
      • **七、总结**

以下是Nginx路由匹配规则的详细解析,包含优先级、匹配语法、实战案例及常见陷阱:

一、Nginx路由匹配核心机制

Nginx通过location指令定义路由规则,匹配顺序基于优先级,具体规则如下:

优先级级别匹配规则示例说明
最高优先级=(精确匹配)location = /api/v1/只匹配完全匹配的URI,优先级最高
次高优先级^~(前缀匹配,最长匹配)location ^~ /api/匹配以/api/开头的URI,且选择最长的匹配路径
第三优先级~(正则匹配)`location ~* .(jpgcss)$`
最低优先级通配符*(模糊匹配)location /files/.*匹配以/files/开头的任意路径

二、匹配规则语法详解

1. 精确匹配 (=)

语法location = /path/ { ... }
特点:仅匹配完全相同的URI,优先级最高
案例

location = /login {proxy_pass http://backend/login;
}

• 只有请求/login时会触发该规则,/login/api不会匹配。

2. 前缀匹配 (^~/)

语法location ^~ /api/ { ... }location /api/ { ... }
特点
^~表示严格前缀匹配,最长匹配优先
• 单斜杠/等同于^~ /,但优先级低于^~
案例

location ^~ /api/v1/ {proxy_pass http://v1-backend;
}
location ^~ /api/v2/ {proxy_pass http://v2-backend;
}

• 请求/api/v1/test匹配第一个规则,/api/v1/old匹配最长路径。

3. 正则匹配 (~~*)

语法
~:区分大小写的正则匹配
~*:不区分大小写的正则匹配
示例

# 匹配所有以.jpg或.png结尾的请求(不区分大小写)
location ~* \.(jpg|jpeg|png)$ {expires 30d;
}

• 正则表达式需用^$包裹以明确匹配范围。

4. 通配符匹配 (*)

语法location /path/*/file.html { ... }
特点
*匹配任意字符(除斜杠)零次或多次。
优先级最低,仅当前面规则未匹配时生效。
案例

location /static/* {alias /var/www/static/;
}

• 请求/static/image.jpg会被映射到/var/www/static/image.jpg

三、路由匹配优先级顺序

Nginx的路由匹配严格遵循优先级顺序

1. = 精确匹配
2. ^~ 前缀匹配(最长匹配)
3. ~ 正则匹配(区分大小写)
4. ~* 正则匹配(不区分大小写)
5. 通配符 *

示例

location /api/ {# 优先级4(通配符)
}location ^~ /api/v1/ {# 优先级2(前缀匹配),匹配/api/v1/及其子路径
}location ~* \.json$ {# 优先级3(正则),匹配所有.json文件
}

• 请求/api/v1/data.json会匹配^~ /api/v1/,而非正则规则。

四、高级路由技巧

1. 条件判断 (if语句)

语法

location /user/ {if ($arg_version = "v2") {proxy_pass http://v2-user-service;}default_type text/html;return 404;
}

注意:避免在location块内使用复杂条件判断,可能导致性能问题。

2. 路径重写 (rewrite指令)

语法

location /old-path/ {rewrite ^/old-path/(.*)$ /new-path/$1 permanent;
}

作用:将/old-path/user重定向到/new-path/user

3. 负载均衡路由

语法

upstream backend {server backend1.example.com;server backend2.example.com;
}location /api/ {proxy_pass http://backend;
}

扩展:结合upstream模块实现加权轮询、IP哈希等策略。

五、实战案例:多版本API路由

需求

/api/v1/* → 版本1
/api/v2/* → 版本2
/admin/* → 管理后台

配置
# 最高优先级:精确匹配/admin/
location = /admin/ {proxy_pass http://admin-backend;
}# 前缀匹配/api/v1/ 和 /api/v2/
location ^~ /api/v1/ {proxy_pass http://v1-api;
}location ^~ /api/v2/ {proxy_pass http://v2-api;
}# 通配符匹配其他/api请求(兜底)
location /api/ {proxy_pass http://default-api;
}

六、常见陷阱与调试

1. 优先级错误

问题:误将通配符规则放在^~规则前。
修复:检查location块的顺序,确保高优先级规则在前。

2. 正则表达式性能

问题:使用低效的正则表达式(如.*开头)导致匹配缓慢。
优化:尽可能使用具体前缀(如~* \.(jpg|css)$代替~* .*$)。

3. 日志调试

指令

error_log /var/log/nginx/error.log warn;
access_log /var/log/nginx/access.log;

调试命令

nginx -t            # 测试配置语法
nginx -s reload     # 重新加载配置
curl -I http://localhost/test  # 查看响应头

七、总结

Nginx路由匹配的核心是优先级顺序规则语法的正确组合:

  1. 优先使用^~前缀匹配实现版本路由。
  2. **正则匹配~***处理动态路径(如文件类型)。
  3. **通配符***作为兜底规则。
  4. 避免在location块内嵌套复杂逻辑,保持配置简洁。

通过合理利用这些规则,可以实现灵活、高效的路由策略,支撑微服务架构的流量治理需求。

相关文章:

【服务器知识】Nginx路由匹配规则说明

Nginx路由匹配规则说明 **一、Nginx路由匹配核心机制****二、匹配规则语法详解**1. **精确匹配 ()**2. **前缀匹配 (^~ 或 /)**3. **正则匹配 (~ 或 ~*)**4. **通配符匹配 (*)** **三、路由匹配优先级顺序****四、高级路由技巧**1. **条件判断 (if语句)**2. **路径重写 (rewrit…...

Docker换源加速(更换镜像源)详细教程(2025.3最新可用镜像,全网最详细)

文章目录 前言可用镜像源汇总换源方法1-临时换源换源方法2-永久换源(推荐)常见问题及对应解决方案1.换源后,可以成功pull,但是search会出错 补充1.如何测试镜像源是否可用2.Docker内的Linux换源教程 换源速通版(可以直…...

OpenAI--Agent SDK简介

项目概述 OpenAI Agents SDK 是一个轻量级但功能强大的框架,用于构建多智能体工作流。它主要利用大语言模型(LLM),通过配置智能体、交接、护栏和跟踪等功能,实现复杂的工作流管理。以下是对其各个部分运行过程和代码流…...

pytorch小记(十三):pytorch中`nn.ModuleList` 详解

pytorch小记(十三):pytorch中nn.ModuleList 详解 PyTorch 中的 nn.ModuleList 详解1. 什么是 nn.ModuleList?2. 为什么不直接使用普通的 Python 列表?3. nn.ModuleList 的基本用法示例:构建一个包含两层全连…...

SpringData Redis:RedisTemplate配置与数据操作

文章目录 引言一、Redis概述与环境准备二、RedisTemplate基础配置三、连接属性配置四、操作String类型数据五、操作Hash类型数据六、操作List类型数据七、操作Set类型数据八、操作ZSet类型数据九、事务与管道操作总结 引言 Redis作为高性能的NoSQL数据库,在分布式系…...

Qt按钮控件常用的API

1.创建按钮 QPushButton *btnnew QPushButton; 以顶层方式弹出窗口控件 代码: #include "widget.h" #include "ui_widget.h" #include"QPushButton"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui-&…...

如何检查CMS建站系统的插件是否安全?

检查好CMS建站系统的插件安全是确保网站安全的重要环节,对于常见的安全检查,大家可以利用以下几种有效的方法和工具,来帮你评估插件的安全性。 1. 检查插件来源和开发者信誉 选择可信来源:仅从官方插件库或可信的第三方开发者处…...

修改HuggingFace模型默认缓存路径

huggingface模型的默认缓存路径是~/.cache/huggingface/hub/ 通常修改为自己的路径会更为方便。 方式一:cache_dir 参数 可以通过from_pretrained函数中的 cache_dir 参数来指定,缺点,每次都需要手动指定,比较麻烦。 如&#x…...

ORA-12541: TNS:no listener

问题描述:使用 PL/SQL Developer 连接数据库时出现ORA-12541错误。 1.查询监听状态 [oraclelocalhost admin]$ lsnrctl statusLSNRCTL for Linux: Version 19.0.0.0.0 - Production on 15-MAR-2025 10:47:57Copyright (c) 1991, 2021, Oracle. All rights reserv…...

【Matlab GUI】封装matlab GUI为exe文件

注:封装后的exe还是需要有matlab环境才能运行 (1)安装MCRinstaller.exe文件,在matlab安装目录下的toolbox/compiler/deploy/win64文件夹里 (2)安装完MCRinstaller.exe,字命令窗口输入&#x…...

【eNSP实战】(续)一个AC多个VAP的实现—将隧道转发改成直接转发

在 一个AC多个VAP的实现—CAPWAP隧道转发 此篇文章配置的基础上,将隧道转发改成直接转发 一、改成直接转发需要改动的配置 (一)将连接AP的接口改成trunk口,并允许vlan100、101、102通过 [AC1]interface GigabitEthernet 0/0/8 …...

Redis能否替代MySQL作为主数据库?深入解析两者的持久化差异与适用边界——基于AOF持久化与关系型数据库的对比

一、Redis的持久化机制与可靠性分析 ​AOF持久化原理与策略 Redis的AOF(Append Only File)通过记录所有写操作命令实现持久化,支持三种策略: ​**always模式**:每条命令执行后立即同步到磁盘,理论上数据丢失…...

机器人ROS学习:Ubuntu22.04安装ROS2和Moveit2实现运动规划

通过本篇文章学习,你可以收获以下内容: 学会在 Ubuntu22.04 上安装 Moveit2学会下载编译运行 Moveit2 样例程序学会使用样例程序进行运动规划等 版本平台 系统版本:ubuntu22.04ROS2 版本:humbleMoveit 版本:moveit2…...

GIT标签(Tag)操作

在Git中&#xff0c;标签&#xff08;Tag&#xff09;用于标记特定的提交点&#xff0c;通常用于发布版本。 切换到需要打标签的分支&#xff1a; git checkout <branch-name>创建标签 git tag v1.0.0 git tag -a v1.0.0 -m "Release version 1.0.0"查看所…...

生成式AI红队测试:如何有效评估大语言模型

OWASP最新指南为组建生成式AI红队或调整现有红队以适应新技术提供了详细的指导。 红队测试是一种经过时间检验的网络安全系统测试和加固方法&#xff0c;但它需要不断适应技术的演变。近年来&#xff0c;生成式AI和大语言模型&#xff08;LLM&#xff09;的爆发&#xff0c;是…...

技术路线图ppt模板_流程图ppt图表_PPT架构图

技术路线图ppt模板 / 学术ppt模板 - 院士增选、国家科技奖、杰青、长江学者特聘教授、校企联聘教授、重点研发、优青、青长、青拔.. / 学术ppt案例 WordinPPT / 持续为双一流高校、科研院所、企业等提供PPT制作系统服务。 - 科学技术奖ppt&#xff1a;自然科学奖 | 技术…...

Leetcode-131.Palindrome Partitioning [C++][Java]

目录 一、题目描述 二、解题思路 【C】 【Java】 Leetcode-131.Palindrome Partitioninghttps://leetcode.com/problems/palindrome-partitioning/description/131. 分割回文串 - 力扣&#xff08;LeetCode&#xff09;131. 分割回文串 - 给你一个字符串 s&#xff0c;请你…...

LeetCode 解题思路 20(Hot 100)

解题思路&#xff1a; 递归定义对称性&#xff1a; 若两棵子树镜像对称&#xff0c;需满足&#xff1a; 当前节点值相等&#xff1b;左子树的左节点与右子树的右节点对称&#xff1b;左子树的右节点与右子树的左节点对称。 终止条件&#xff1a; 两个节点均为空 → 对称&am…...

挖矿------获取以太坊测试币

文章目录 挖矿------获取以太坊测试币通过水龙头获取以太坊测试币了解Sepolia是什么&#xff1f;水龙头&#xff08;Faucet&#xff09;是什么&#xff1f;Gitcoin Passport是什么&#xff1f; 操作1.MetaMask钱包2.将MetaMask切换到Sepolia测试网络3.用MetaMask连接Gitcoin Pa…...

每天五分钟深度学习框架pytorch:基于pytorch搭建循环神经网络RNN

本文重点 我们前面介绍了循环神经网络RNN,主要分析了它的维度信息,其实它的维度信息是最重要的,一旦我们把维度弄清楚了,一起就很简单了,本文我们正式的来学习一下,如何使用pytorch搭建循环神经网络RNN。 RNN的搭建 在pytorch中我们使用nn.RNN()就可以创建出RNN神经网络…...

XEasyWork:面向AI应用的可视化工作流开发平台

文章目录 前言 一、平台核心价值 1.1产品定位 1.2 技术优势 二、技术架构解析 2.1战略级整合 自主开发模块 2.2集成开源项目 三、体验地址 三、未来规划 总结 前言 在人工智能技术快速落地的今天&#xff0c;开发者在构建AI应用时仍面临两大挑战&#xff1a;技术栈复杂带来的高…...

C#进阶(多线程相关)

1。进程&#xff1f; 进程&#xff08;Process&#xff09;是计算机中的程序关于某数据集合上的一次运行活动&#xff0c;【是系统进行资源分配的基本单位】&#xff0c;是操作系统结构的基础。在早期面向进程设计的计算机结构中&#xff0c;进程是程序的基本执行实体&#xf…...

【C++】:C++11详解 —— 右值引用

目录 左值和右值 左值的概念 右值的概念 左值 vs 右值 左值引用 和 右值引用 左值引用 右值引用 左值引用 vs 右值引用 使用场景 左值引用的使用场景 左值引用的短板 右值引用的使用场景 1. 实现移动语义&#xff08;资源高效转移&#xff09; 2. 优化容器操作&a…...

【css酷炫效果】纯CSS实现虫洞穿越效果

【css酷炫效果】纯CSS实现穿越效果 缘创作背景html结构css样式完整代码基础版进阶版&#xff08;虫洞穿越&#xff09; 效果图 想直接拿走的老板&#xff0c;链接放在这里&#xff1a;https://download.csdn.net/download/u011561335/90491973 缘 创作随缘&#xff0c;不定时…...

Linux IP 配置

Linux IP 配置 1 环境介绍2 网卡信息配置3 使用nmtui工具配置4 更多Linux命令学习使用列表 1 环境介绍 虚拟机&#xff0c;服务器安装系统完成后&#xff0c;先要配置ip 地址&#xff0c;这样可以方便远程若是物理服务器一般会有4个网卡信息麒麟v10&#xff0c;CentOS7&#x…...

设计模式之装饰器模式:原理、实现与应用

引言 装饰器模式&#xff08;Decorator Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许你通过将对象放入包含行为的特殊封装对象中来为原对象动态添加新的行为。装饰器模式提供了一种灵活的替代方案&#xff0c;避免了通过继承扩展功能的局限性。本文将深入探讨装…...

c语言笔记 结构体基础

目录 基础知识 结构体定义 基础知识 在c语言中变量是有类型的&#xff0c;比如整型&#xff0c;char型&#xff0c;浮点型等&#xff0c;这些都是单一的类型&#xff0c;那么如果说我要定义一个学生的信息&#xff0c;那么这些单一的类型是不足以表达一个学生的全部信息&#…...

Vue 登录 记住密码,设置存储时间

Vue 登录 记住密码&#xff0c;设置存储时间 一、手动存储login.vue 二、使用vue-cookies插件main.jslogin.vue 一、手动存储 login.vue 提示&#xff1a; // 设置cookie方法 setCookie(loginName, password, days) {let text encryptDes(password, des123)//使用des方法加…...

C++ 学习笔记(三)—— 入门+类和对象

1、内联函数&#xff08;inline&#xff09; 内联函数主要是解决C语言的宏的缺陷提出来的&#xff1b; 宏的缺陷&#xff1a; 1&#xff09;容易出错&#xff0c;语法坑很多&#xff1b; 2&#xff09;不能调试&#xff1b; 3&#xff09;没有类型安全的检查&#xff1b; 宏的…...

KVM安全模块生产环境配置与优化指南

KVM安全模块生产环境配置与优化指南 一、引言 在当今复杂多变的网络安全环境下&#xff0c;生产环境中KVM&#xff08;Kernel-based Virtual Machine&#xff09;的安全配置显得尤为重要。本指南旨在详细阐述KVM安全模块的配置方法&#xff0c;结合强制访问控制&#xff08;M…...