Nginx Location映射规则总结归纳与最佳实践

2025-06-06 15:50

本文主要是介绍Nginx Location映射规则总结归纳与最佳实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则...

Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程。下面基于官方文档和实战经验的总结:

一、Location匹配规则与优先级

1. 匹配模式

Nginx支持5种location修饰符,优先级从高到低为:

修饰符说明示例
=精确匹配(最高优先级)location = /logo.png
^~最长前缀匹配(匹配后停止正则检查)location ^~ /static/
~正则匹配(区分大小写,按配置文件顺序匹配)location ~ \.php$
~*正则UzEmpOdwW匹配(不区分大小写)`location ~* .(jpg
普通前缀匹配(按最长匹配原则,优先级最低)location /blog/

2. 优先级顺序

Nginx按以下顺序匹配location块:

精确匹配(=
仅当请求URI与location后的字符串完全匹配时生效。正则匹配(~/~*
按配置文件中的书写顺序依次匹配,首个匹配的正则生效。最长前缀匹配(^~
选择匹配URI前缀最长location块。普通前缀匹配
按最长匹配原则选择,若多个location匹配,选择最先定义的。默认匹配(location /
兜底处理未匹配其他规则的请求。

3. 匹配示例

假设配置如下:

locphpation = /exact { ... }          # 精确匹配
location ^~ /prefix { ... }        # 最长前缀匹配
location ~ \.png$ { ... }          # 正则匹配(区分大小写)
location /general { ... }          # 普通前缀匹配
location / { ... }                 # 默认匹配
  • 请求/exact → 匹配location = /exact
  • 请求/prefix/long → 匹配location ^~ /prefix^~优先级高于普通前缀)。
  • 请求/image.PNG → 匹配location ~* \.(jpg|png)$(不区分大小写的正则)。
  • 请求/general/path → 匹配location编程 /general

二、Proxy_pass路径处理规则

proxy_pass指令用于将请求转发到后端服务,其路径拼接逻辑与location配置紧密相关

1. 路径拼接规则

场景示例配置请求URI转发目标
proxy_pass/结尾location /api/ { proxy_pass http://backend/; }/api/userhttp://backend/user
proxy_pass不带/location /api { proxy_pass http://backend; }/api/userhttp://backend/api/user
正则locationlocation ~ ^/app/(.*) { proxy_pass http://app/$1; }/app/v1/datahttp://app/v1/data

关键规则

  • /proxy_pass的URL以/结尾时,替换location匹配的部分。
  • 不带/proxy_pass的URL不带/时,追加location匹配后的完整路径。

2. 路径截取与重写

通过rewrite指令可动态修改转发路径:

location ~* ^/api/v1/ {
    rewrite ^/api/v1/(.*) /$1 break;  # 截取/api/v1/后的路径
    proxy_pass http://backend;
}

请求/api/v1/user/123 android→ 转发到http://backend/user/123

3. 特殊场景处理

Unix Socket转发

location /unix/ {
    proxy_pass http://unix:/var/run/backend.sock:/;
}

避免301重定向

location /app {
    proxy_pass http://backend;
}
# 请求/app(无结尾/)时,Nginx可能自动重定向到/app/
# 使用精确匹配避免:
location = /app {
    proxy_pass http://backend;
}

三、配置优化与最佳实践

精确匹配优先
location =块置于配置文件顶部,减少正则匹配开销。

正则匹配顺序
将高频请求的正则规则前置,提升匹配效率。

路径设计一致性
确保locationproxy_pass的URL格式(是否带/)一致,避免路径拼接错误。

监控
使用error_logAccess_log跟踪匹配过程,优化配置。

四、完整配置示例

server {
    listen 80;
    server_name example.com;
    # 精确匹配静态文件
    location = /favicon.ico {
        log_not_found off;
        access_log off;
        root /var/www/icons;
    }
    # 最长前缀匹配API请求
    location ^~ /api/ {
        proxy_pass http://api_server;
        proxyandroid_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
    }
    # 正则匹配图片资源(不区分大小写)
    location ~* \.(jpg|png|gif)$ {
        expires 30d;
        root /var/www/images;
    }
    # 默认匹配
    location / {
        root /var/www/html;
        index index.html;
    }
}

配置说明

  • 精确匹配favicon.ico,关闭日志提升性能。
  • ^~ /api/匹配所有以/api/开头的请求,转发到后端服务。
  • 正则匹配图片文件,设置30天缓存。
  • 未匹配的请求由location /处理,返回静态文件。

到此这篇关于Nginx Location映射规则总结归纳的文章就介绍到这了,更多相关Nginx Location映射规则内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于Nginx Location映射规则总结归纳与最佳实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154940

相关文章

Olingo分析和实践之EDM 辅助序列化器详解(最佳实践)

《Olingo分析和实践之EDM辅助序列化器详解(最佳实践)》EDM辅助序列化器是ApacheOlingoOData框架中无需完整EDM模型的智能序列化工具,通过运行时类型推断实现灵活数据转换,适用... 目录概念与定义什么是 EDM 辅助序列化器?核心概念设计目标核心特点1. EDM 信息可选2. 智能类

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

SpringBoot整合(ES)ElasticSearch7.8实践

《SpringBoot整合(ES)ElasticSearch7.8实践》本文详细介绍了SpringBoot整合ElasticSearch7.8的教程,涵盖依赖添加、客户端初始化、索引创建与获取、批量插... 目录SpringBoot整合ElasticSearch7.8添加依赖初始化创建SpringBoot项

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

Nginx安全防护的多种方法

《Nginx安全防护的多种方法》在生产环境中,需要隐藏Nginx的版本号,以避免泄漏Nginx的版本,使攻击者不能针对特定版本进行攻击,下面就来介绍一下Nginx安全防护的方法,感兴趣的可以了解一下... 目录核心安全配置1.编译安装 Nginx2.隐藏版本号3.限制危险请求方法4.请求限制(CC攻击防御)

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx