详解nginx的root与alias

news2025/4/28 2:59:09

文章目录

  • 1. 结论
  • 2. 详解root
    • 2.1 基本用法
    • 2.2 location的最左匹配原则
    • 2.3 index
    • 2.4 nginx location解析url工作流程
    • 2.5 末尾'/'
  • 3. 详解alias
    • 3.1 基本用法
  • 4. 特殊情况
    • 4.1 alias指定文件
    • 4.2 root指定文件

nginx版本: 1.18.0

1. 结论

location命中后

如果是root,会把请求url的 ip/域名+port替换为root指定的目录,访问资源

如果是alias,会把请求url的ip/域名+port+匹配到的路径替换为alias指定的目录,访问资源

2. 详解root

2.1 基本用法

以请求http://example.com/foo/bar/hello.html 为例,location配置如下

location /foo {
    root /home/hfy/;
}

匹配到/foo,url的域名+port替换为root指定的目录,即url中的examp.com被替换为了/home/hfy,所以实际访问的路径为/home/hfy/foo/bar/hello.html

为了更好理解,再来一个例子,请求的url不变,location配置更改为

location /foo/bar {
    root /home/hfy/;
}

匹配到/foo/bar,url的域名+port替换为root指定的目录,即url中的examp.com被替换为了/home/hfy,所以实际访问的路径仍然为/home/hfy/foo/bar/hello.htmlroot在替换时不会替换匹配到的路径

2.2 location的最左匹配原则

location会从url最左边的路径匹配,如果一致则命中该location。只有中间匹配到不会命中。
比如请求的url为http://example.com/foo/bar/hello.html ,location为

location /bar {
    root /home/hfy/;
}

不会命中该location,因为从url中的/foo开始匹配,与location /bar不一致,不会命中,如果url更改为http://example.com/bar/hello.html 才会命中该规则

2.3 index

在location内部其实默认配置了一条规则index index.html,补全后的规则如下

location /foo {
    root /home/hfy/;
    index index.html;
}

假设我们访问的url为http://example.com/foo/bar ,匹配到/foo,实际访问的路径为/home/hfy/foo/bar。如果我们的bar是一个文件夹,其中如果包含index.html文件,则会把该文件返回。所以index的作用是,当实际访问的是一个目录时,会返回该目录中index指定的文件,如果该目录中不存在index指定的文件,则会返回403。

在访问http://example.com/foo/bar ,时我们打开浏览器的控制台,查看发送的请求,会发现发生了一个301重定向,http://example.com/foo/bar 被重定向为http://example.com/foo/bar/ ,由此引发了新的问题,为什么会发生重定向,url末尾的/,location 匹配路径末尾的/,以及root 指定目录末尾的/都表示什么意思

2.4 nginx location解析url工作流程

经过我的多次测试,发现解析url工作流程图如下
请添加图片描述

上述的工作流程,假设了url末尾没有加/,如果末尾包含/,解析流程为上图中绿色部分。例如url为http://example.com/foo/ ,如果foo不存在或者是文件,则直接返回404,如果是foo是目录,则进入到绿色部分流程。如果foo目录中存在index指定的文件,则返回该文件。如果不存在返回403。从这个例子可以看出,url末尾加/表示要访问一个目录,如果实际是个文件,nginx会返回404

根据上述的流程图,我们看一下2.3中的重定向问题,在访问http://example.com/foo/bar 为什么发生了301重定向。

首先命中如下规则

location /foo {
    root /home/hfy/;
    index index.html;
}

根据上述的流程图,先替换域名+port,实际访问的路径为/home/hfy/foo/bar,然后nginx发现bar不是文件而是个目录(文件夹),所以重定向为了http://example.com/foo/bar/ 访问bar这个目录中的index.html文件

2.5 末尾’/’

然后再看一下2.3中的另一个问题,末尾的/分别是什么含义
事先声明,仅是我个人粗浅的理解,根据对不同情况的测试,尝试总结 '/'的含义

  • url末尾/的含义

http://example.com/foo/bar 表示我们把bar当成一个文件,想要访问bar文件
http://example.com/foo/bar/ 表示我们把bar当成一个目录,想要访问bar目录下index指定的文件

  • location 匹配路径末尾/的含义
location /foo {
    root /home/hfy/;
    index index.html;
}

/foo 既能匹配http://example.com/foo 也能匹配 http://example.com/foo/

location /foo/ {
    root /home/hfy/;
    index index.html;
}

/foo/只能匹配http://example.com/foo/

  • root 指定目录末尾/的含义
location /foo {
    root /home/hfy/;
    index index.html;
}

/home/hfy 表示把hfy当成目录或者文件

/home/hfy/ 表示只把hfy当成目录

root后面指定的都应该是目录 (不过alias有种特殊情况,后面会提到)

对于这三个斜杠,在实践中可以有如下使用方案

  1. url末尾不加/,如果需要带/时依靠nginx自动帮我们重定向加/
  2. location 路径不加/,这样末尾有无/的url都能匹配到
  3. root或者alias指定的目录后面加/,明确表示root指定的是目录,增强配置的可读性

3. 详解alias

3.1 基本用法

以请求http://example.com/foo/bar/hello.html为例,location配置如下

location /foo {
    alias /home/hfy/;
}

匹配到/foo,url的ip/域名+port+匹配到的路径替换为alias指定的目录,即url中的example.com/foo被替换为了/home/hfy,所以实际访问的路径为/home/hfy/bar/hello.html

同样再来一个例子,请求的url不变,如果location配置更改为

location /foo/bar {
    alias /home/hfy/;
}

匹配到/foo/bar,url的ip/域名+port+匹配到的路径替换为alias指定的目录,即url中的example.com/foo/bar被替换为了/home/hfy,所以实际访问的路径为/home/hfy/hello.htmlalias在替换时会替换匹配到的路径

alias其余特性,最左匹配、index、location解析url工作流程、末尾’/'与root一致。

4. 特殊情况

4.1 alias指定文件

  • case 1

url http://example.com/foo

/home/hfy/foo是一个文件

location配置如下

location /foo {
    alias /home/hfy/foo;
}

实际访问路径/home/hfy/foo,nginx返回foo文件

这就是上面说的特例,alias也可以指定文件,并且正常返回了要访问的文件。但是实际一般不会用alias指定文件。

  • case 2

url http://example.com/foo

/home/hfy/foo是一个文件

location配置如下

location /foo {
    alias /home/hfy/foo/;
}

实际访问路径/home/hfy/foo,alias指定 /home/hfy/foo/是一个目录,而foo是一个文件,返回404

  • case 3
    url http://example.com/foo/

/home/hfy/foo是一个文件

location配置如下

location /foo/ {
    alias /home/hfy/foo;
}

实际访问路径/home/hfy/foo/要访问目录,alias指定/home/hfy/foo是目录或文件,而foo是一个文件,返回了500

  • case 4

url http://example.com/foo/

/home/hfy/foo是一个文件

location配置如下

location /foo/ {
    alias /home/hfy/foo/;
}

实际访问路径/home/hfy/foo/,alias指定/home/hfy/foo/是一个目录,而foo是一个文件,返回了404

  • case 5

url http://example.com/

/home/hfy/foo是一个文件

location配置如下

location / {
    alias /home/hfy/foo;
}

实际访问路径/home/hfy/foo,但是返回了500

  • case 6

url http://example.com/

/home/hfy/foo是一个文件

location配置如下

location / {
    alias /home/hfy/foo/;
}

实际访问路径/home/hfy/foo,返回404

4.2 root指定文件

  • case 1

url http://example.com/foo

/home/hfy/foo是一个文件

location配置如下

location /foo {
    root /home/hfy/foo;
}

实际访问路径/home/hfy/foo/foo,不存在,返回404

  • case 2

url http://example.com/foo

/home/hfy/foo是一个文件

location配置如下

location /foo {
    root /home/hfy/;
}

实际访问路径/home/hfy/foo,返回foo文件

  • case 3

url http://example.com/foo/

/home/hfy/foo是一个文件

location配置如下

location /foo {
    root /home/hfy/;
}

location配置如下

location /foo/ {
    root /home/hfy/;
}

实际访问路径/home/hfy/foo/要访问目录,/home/hfy/foo是文件,返回404

  • case 4

url http://example.com/

/home/hfy/foo是一个文件

location配置如下

location / {
    root /home/hfy/foo;
}

实际访问路径/home/hfy/foo,foo是一个文件,但是却返回404

  • case 5

url http://example.com/

/home/hfy/foo是一个文件

location配置如下

location / {
    root /home/hfy/foo/;
}

实际访问路径/home/hfy/foo,foo是一个文件,但是却返回404

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/48304.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Anaconda、Conda、pip、Virtualenv的区别

一、Anaconda 1.1 简介 Anaconda是一个包含180的科学包及其依赖项的发行版本。其包含的科学包包括:conda, numpy, scipy, ipython notebook等。 二、Conda 2.1 简述 conda是包及其依赖项和环境的管理工具。 适用语言:Python, R, Ruby, Lua, Scala, …

什么是CRM系统,它如何支持客户营销管理?

简道云回款&销售排名看板什么是CRM控制系统,它怎样全力支持顾客网络营销管理工作? 顾客关系管理工作(CRM)是国际品牌用以培育与顾客关系的技术。这些应用软件系统意在协助产品销售和服务全权更有效地与顾客沟通交流。由于91%的雇员超过11人的企业使用CRM&…

Vue3 —— 利用vite+vue创建一个vue3项目

前言 本文主要讲解如何利用vitevue创建第一个项目以及vue3的基础知识点 一、创建一个vue3项目 这里我们主要介绍如何利用 vitevue3创建项目 1.有关vite Vite(法语意为 "快速的",发音 /vit/,发音同 "veet")是…

AWS Lambda函数实战

AWS Lambda函数实战 实战效果&#xff1a;开发一个函数&#xff0c;它会关注事件中的某个名字&#xff0c;并返回“Hello<名字>&#xff01;”。如果输入事件没有提供名字&#xff0c;则函数返回一个更加通用的问候语“Hello World&#xff01;”。 AWS Lambda函数实战A…

vue后台实现点击图片放大

需求&#xff1a; 点击小图可以放大&#xff0c;放大后&#xff0c;通过手势等比例放大缩小、左右切换图、旋转、关闭。由于element-ui版本较低不支持使用图片放大的image组件。 代码 父组件&#xff1a; <template><div><!-- 放大图 --><el-image-vie…

数商云供应链管理系统助力化工行业企业实现客户订单管理可视化

订单管理是现代企业商务业务的重要组成部分&#xff0c;可以帮助企业解决订单管理低效、混乱等问题。随着产业互联网时代的到来&#xff0c;越来越多企业放弃传统费时费力的手动操作&#xff0c;开始应用数字化的管理工具来提高企业订单管理的水平。这里以化工行业企业为例&…

一文详解,数据仓库、数据库、数据中台、数据湖的区别

数据时代&#xff0c;各行业的企业都已经开始通过数据库来沉淀数据&#xff0c;但是真的论起数据库、数据仓库、数据中台&#xff0c;还是新出现的数据湖&#xff0c;它们的概念和区别&#xff0c;可能知道的人就比较少了&#xff0c;今天我们详细来比较了解一下。 数据仓库是…

ArrayList 和 LinkedList 之间应该怎么选择

这篇文章是来自知乎上的一个问题。 相信很多人在面试时都被问过这个问题&#xff0c;然后一般回答&#xff1a;ArrayList在指定下标访问时快&#xff0c;LinkedList在插入/删除元素时快。 其实这是一种人云亦云的谬误。可能最初有人这么回答&#xff0c;然后不加验证地转来转…

猿如意开发工具|JetBrains GoLand

一、猿如意是什么&#xff1f; 是CSDN推出的桌面客户端&#xff0c;旨在为广大开发者提供效率工具、文档、代码等优质工具和内容&#xff0c;提升开发者的学习和工作效率&#xff0c;详情点击&#x1f449;【猿如意官网】。为了让更多开发者更好的认识、了解、使用猿如意中的每…

项目管理(如何进行项目质量管理)

需要进行的工作&#xff1a; 1、规划项目质量管理&#xff1a;识别项目及其可交付成果的质量要求和/或标准&#xff0c;并书面描述项目将如何证明 符合质量要求和/或标准的过程。 2、管理质量&#xff1a;管理质量是把组织的质量政策用于项目&#xff0c;并将质量管理计划转化…

蓝桥杯嵌入式cubeMX自动生成的gpio.c文件解析

文章目录前言一、如何生成gpio.c文件二、gpio.c内部实现总结前言 这篇文章将带大家了解一下cubeMX自动生成的gpio.c文件。 一、如何生成gpio.c文件 在LED这篇文章中我们配置了控制LED的GPIO引脚&#xff0c;选择了PD2和PC8 PC9这三个引脚&#xff0c;并且将他们都设置为了输…

数图互通高校房产管理系统——住房管理

1、住房管理 1.1 住房档案 住房模块的管理主要是针对学校的承租住宅和已售住宅的管理&#xff0c;用于登记已售住宅的产权人信息&#xff0c;记录承租住宅的租赁起止日期、月租金等基本信息。 支持住房的坐落信息、楼栋、房间信息的维护。坐落位置主要维护校区编号、校区名称…

说明白正反向代理,以及Nginx和Gunicorn

一&#xff1a;什么是Nginx Nginx的产生 没有听过Nginx&#xff1f;那么一定听过它的"同行"Apache吧&#xff01;Nginx同Apache一样都是一种WEB服务器。基于REST架构风格&#xff0c;以统一资源描述符(Uniform Resources Identifier)URI或者统一资源定位符(Uniform …

图像质量评价指标metrics:PSNR 、SSIM、LPIPS

一、PSNR&#xff08;峰值信噪比&#xff09; 1.定义 是基于对应像素点间的误差&#xff0c;即基于误差敏感的图像质量评价&#xff0c;由于并未考虑到人眼的视觉特性&#xff08;人眼对空间频率较低的对比差异敏感度较高&#xff0c;人眼对亮度对比差异的敏感度较色度高&…

HTTP协议中的Cookie 和 Session

Cookie Session一 Cookie1.Cookie是什么?2.Cookie的工作机制二 Session1.Session的工作机制三 Cookie 和 Session 的区别一 Cookie 1.Cookie是什么? Cookie是一组键值对保存在客户端&#xff0c;服务器给浏览器的一组键值对(Sessionidxxxxxxx)通过Cookie来传递给客户端&…

比搞笑诺奖还离谱,看完国产AIGC最新创作,把我给整不会了

杨净 萧箫 发自 凹非寺量子位 | 公众号 QbitAI现在&#xff0c;AI生成的东西&#xff0c;“真实”得都让我有点害怕了——只是给出《马斯克获得诺贝尔物理学奖》这个标题&#xff0c;AI竟然就刷刷刷几下&#xff0c;蹦出了一整套大纲来&#xff1f;&#xff01;如果让AI生成一些…

5G WiFi 安信可 BW16 模组 RTL8720DN 入门笔记 2:Linux 搭建二次开发SDK开发环境,点亮一盏LED灯。

首先按照环境所依赖的包&#xff1a; sudo apt-get install git wget libc6-i386 lib32ncurses5 make bc gawk ncurses-dev 开始获取SDK源码&#xff0c;并且修改权限&#xff1a; git clone https://github.com/ambiot/ambd_sdk.git sudo chmod -R 777 ambd_sdk然后开始编译…

傻白入门芯片设计,三大基本定律(十)

1.摩尔定律&#xff08;Moores Law&#xff09;&#xff1a;集成电路上可以容纳的晶体管数目在大约每经过18个月到24个月便会增加一倍。换言之&#xff0c;处理器的性能大约每两年翻一倍&#xff0c;同时价格下降为之前的一半。。 2.登纳德缩放定律&#xff08;Dennard Scalin…

一些跨平台技术方案的经验参考

今天就站在一个小开发的视角分享一下一个小项目是如何进行跨平台方案选型的 本系列文章先站在公司的的角度对产品技术选型进行分析&#xff0c;然后再根据我们项目实际开发经验进行汇总&#xff0c;供大家参考。 目前大前端技术也非常丰富&#xff0c;可以实现&#xff0c;一…

Shader中需要数学知识

在Shader的学习中&#xff0c;我们可能需要一些数学知识&#xff0c;我也是学习了一段时间&#xff0c;之前数学的知识都忘了&#xff0c;重新来一遍吧&#xff0c;我把学习的点分享一下。 向量&#xff1a; 点乘&#xff1a; 向量A向量B A向量的模 * B向量的模 * cosθ 一般…