Nginx Location匹配顺序详解

发布时间:2023-05-19

Nginx是一款高性能的Web服务器软件,支持反向代理、负载均衡、静态缓存、SSL协议以及HTTP2等诸多功能。而在Nginx中,location指令是非常重要的一个配置项,用于配置URL请求的匹配规则。在实际应用过程中,不同的location配置可能会发生冲突,因此Nginx提供了一套规则进行匹配、选择最佳匹配项。本文将从不同的维度详细阐述Nginx Location匹配顺序。

一、匹配顺序全面介绍

Nginx location匹配顺序主要涉及三种类型:精确匹配、正则表达式匹配和普通匹配。

  1. 精确匹配:精确匹配可以匹配到URL请求中完全匹配的部分,使用=符号进行匹配。当匹配成功时,nginx将会停止搜索其他location并直接使用该location配置执行请求。示例如下:
    server {
        location = /demo {
            root /var/www;
            index index.html index.php;
        }
    }
    
    请求/demo时,将会精确匹配到location配置,并使用该配置执行请求。
  2. 正则表达式匹配:Nginx支持Perl风格的正则表达式,使用~符号进行匹配。若成功匹配,将会停止其他location的搜索并执行该location的配置。示例如下:
    server {
        location ~ /demo(\/\d{3}) {
            root /var/www;
            index index.html index.php;
        }
    }
    
    请求/demo/001将会正则匹配到location配置,并使用该配置执行请求。
  3. 普通匹配:普通匹配指没有使用任何特殊符号的字符串匹配,如果匹配成功将会停止搜索其他location配置并使用该配置执行请求。示例如下:
    server {
        location /demo {
            root /var/www;
            index index.html index.php;
        }
    }
    
    请求/demo(或/demo/xxx)将会普通匹配到location配置,并使用该配置执行请求。

二、匹配顺序优先级详解

当存在多个location匹配时,nginx将会按照优先级进行匹配,优先级高的匹配规则会被优先使用。Nginx location优先级按照以下顺序排列:

  1. 精确匹配(=)
  2. 正则匹配(*)
  3. 最长普通前缀匹配
  4. 普通前缀匹配 对于优先级相同的匹配规则,nginx将会按照配置文件的顺序进行匹配并选择第一个匹配的location配置执行。 下面是一些示例,用户可以更好地理解优先级排序:
# 正则表达式匹配
location ~ /user/(\d+){
    root /var/www;
    index index.html index.php;
}
# 最长普通前缀匹配
location /user {
    root /var/www;
    index index.html index.php;
}
# 普通前缀匹配
location / {
    root /var/www;
    index index.html index.php;
}

当URL请求为/user/123时,将会正则表达式匹配到第一个location /user/(\d+)配置;当请求为/user/hello时,则会使用第二个location /user配置;其他请求将会使用第三个location /配置。

三、匹配规则建议

  1. 尽可能使用精确匹配:精确匹配最为高效,可以直接命中,提升Nginx性能。
  2. 谨慎使用正则匹配:正则表达式匹配是一种十分灵活的匹配方式,但是性能相对精确匹配会有所下降。
  3. 非特殊情况下尽可能使用最长普通前缀匹配:使用最长普通前缀匹配可以减少无用匹配,提升匹配效率。
  4. 避免匹配重复路由:重复的路由会对匹配规则造成影响,应避免出现此类问题。 总之,Nginx location匹配顺序的理解和使用是Nginx服务器配置中非常重要的一部分。掌握好这一部分内容可以大幅提高Nginx服务器的性能,推荐用户多多使用这些匹配规则。