Nginx Location配置详解


一、语法

Location 是 Nginx 中一个非常核心的配置,关于Location,举个简单的配置例子:

server {
    listen 80;
    server_name 10.0.7.115;
    location / {
        root /data/app/;
        index index.html;
    }
}

当访问 http://10.0.7.115:80 的时候,返回的是 /data/app/index.html 文件。

Location具体语法:

location [ = | ~ | ~* | ^~ ] uri { ... }

重点看方括号中的 [ = | ~ | ~* | ^~ ],其中 | 分隔的内容表示你可能会用到的语法,其中:

  • = 表示精确匹配:
location = /test {
    return 200 "hello";
}

例如:

/test              ok
/test/             not ok
/test2             not ok
/test/2            not ok

  • ~ 表示区分大小写的正则匹配:
location ~ ^/test$ {
    [configuration] 
}

例如:

/test              ok
/Test              not ok
/test/             not ok
/test2             not ok

  • ~* 表示不区分大小写的正则匹配:
location ~* ^/test$ {     
    [configuration] 
}

例如:

/test               ok
/Test               ok
/test/              not ok
/test2              not ok

  • ^~ 表示 uri 以某个字符串开头:
location ^~ /images/ {    
    [configuration] 
}

例如:

/images/1.gif        ok

  • / 表示通用匹配:
location / {     
    [configuration] 
}

例如:

/index.html           ok
location /test {
    [configuration] 
}

例如:

/test                 ok
/test2                ok
/test/                ok

二、匹配顺序

Location的定义分为两种:

  • 前缀字符串(prefix string)

  • 正则表达式(regular expression),具体为前面带 ~* 和 ~ 修饰符

当存在多个 Location 的时候,匹配的顺序为:

  • 检查使用前缀字符串的 locations,在使用前缀字符串的 locations 中选择最长匹配的,并将结果进行储存;

  • 如果符合带有 = 修饰符的URI,则立刻停止匹配

  • 如果符合带有 ^~ 修饰符的URI,则也立刻停止匹配

  • 然后按照定义文件的顺序,检查正则表达式,匹配到就停止

  • 当正则表达式匹配不到的时候,使用之前储存的前缀字符串;

总结:

  • 顺序上

    • 前缀字符串顺序不重要,按照匹配长度来确定

    • 正则表达式按照定义顺序

  • 优先级上

    • = 修饰符最高,^~ 次之,再者是正则,最后是前缀字符串匹配。

我们举几个简单的例子进行说明

请求URI如下:

/document

示例一:

配置:

server {
    location /doc {
        [ configuration A ] 
    }
    location /docu {
        [ configuration B ] 
    }
}

匹配结果:

configuration B

注:虽然 /doc 也能匹配到,但 在顺序上,前缀字符串顺序不重要,按照匹配长度来确定


示例二:

server {
    location ~ ^/doc {
        [ configuration A ] 
    }
    location ~ ^/docu {
        [ configuration B ] 
    }
}

匹配结果:

configuration A

注:虽然 ~ ^/docu 也能匹配到,但 正则表达式则按照定义顺序


示例三:

server {
    location ^~ /doc {
        [ configuration A ] 
    }
    location ~ ^/docu {
        [ configuration B ] 
    }
}

匹配结果:

configuration A

注:虽然 ~ ^/docu 也能匹配到,但 ^~优先级更高


示例四:

server {
    location /document {
        [ configuration A ] 
    }
    location ~ ^/docu {
        [ configuration B ] 
    }
}

匹配结果:

configuration B

注:虽然 /document 也能匹配到,但 正则的优先级更高


三、root 与 alias 的区别

当我们这样设置 root 的时候:

location /i/ {
    root /data/w3;
}

当请求 /i/top.gif/data/w3/i/top.gif 会被返回。

当我们这样设置 alias 的时候:

location /i/ {
    alias /data/w3/images/;
}

当请求 /i/top.gif/data/w3/images/top.gif 会被返回。


两者的区别:

  • root 是直接拼接 root + location

  • alias 是用 alias 替换 location


四、server 和 location 中的 root

server 和 location 中都可以使用 root,举个例子:

server {
    listen 80;
    server_name 10.0.7.115;
        root /data/app/;
        location / {
          root /data/web/;
          index index.html;
    }
}

如果两者都出现,是怎样的优先级呢?

简单的来说,就是 就近原则,如果 location 中能匹配到,就是用 location 中的 root 配置,忽略 server 中的 root,当 location 中匹配不到的时候,则使用 server 中的 root 配置。

  • 14
    点赞
  • 82
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
nginx配置中,location用于定义URL与本地文件系统的映射关系。\[1\]在nginx配置中,可以使用多个location块来匹配不同的URL。每个location块可以包含不同的指令来处理请求。例如,可以使用location指令来指定根目录、索引文件等。\[2\]在配置中,可以使用location = /来指定一个精确匹配的URL,而location /可以用于匹配任意URL。\[3\]此外,还可以使用proxy_pass指令将请求转发给后端应用服务器,或者使用location指令处理静态文件请求。 #### 引用[.reference_title] - *1* [Nginxlocation配置详解和实列](https://blog.csdn.net/m0_52091913/article/details/127284845)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v4^insert_chatgpt"}} ] [.reference_item] - *2* [Nginx Location配置详解](https://blog.csdn.net/wangzhongshun/article/details/126434539)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v4^insert_chatgpt"}} ] [.reference_item] - *3* [Nginx配置location详解](https://blog.csdn.net/u012260238/article/details/102498474)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v4^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值