nginx配置 location root

https://jasonhzy.github.io/2016/08/25/nginx-alias-root/

http://blog.csdn.net/21aspnet/article/details/6583335

 

nginx指定文件路径有两种方式root和alias,root与alias主要区别在于nginx如何解释location后面的uri,这会使两者分别以不同的方式将请求映射到服务器文件上。

最基本的区别

alias 指定的目录是准确的,给location指定一个目录。
root 指定目录的上级目录,并且该上级目录要含有locatoin指定名称的同名目录
以root方式设置资源路径:

语法: root path;
配置块: http、server、location、if

以alias 方式设置资源路径

语法: alias path;
配置块: location

Example:

location /img/ {
	alias /var/www/image/;
}
#若按照上述配置的话,则访问/img/目录里面的文件时,ningx会自动去/var/www/image/目录找文件
location /img/ {
	root /var/www/image;
}
#若按照这种配置的话,则访问/img/目录下的文件时,nginx会去/var/www/image/img/目录下找文件


注意: 

1.使用alias时,目录名后面一定要加”/“。
2.使用alias标签的目录块中不能使用rewrite的break。
3.alias在使用正则匹配时,必须捕捉要匹配的内容并在指定的内容处使用。
4.alias只能位于location块中

配置alias支持PHP fastcgi解析

location /app {
	alias /project/app/;
	index index.php;			
	location ~ \.php$ { #方案一
		fastcgi_pass 127.0.0.1:9100;
		fastcgi_index  index.php;
		include fastcgi.conf;
	}
}

#location ~ /app/.+\.php$ { #方案二
#	rewrite /app/(.+\.php) /$1 break;
#	include fastcgi.conf;
#	fastcgi_pass 127.0.0.1:9100;
#	fastcgi_index index.php;
#	fastcgi_param SCRIPT_FILENAME /project/app/$fastcgi_script_name;
#}

 

 

 

 

 

===============

nginx貌似没有虚拟目录的说法,因为它本来就是完完全全根据目录来设计并工作的。

如果非要给nginx安上一个虚拟目录的说法,那就只有alias标签比较“像”,干脆来说说alias标签和root标签的区别吧。

最基本的区别:alias指定的目录是准确的,root是指定目录的上级目录,并且该上级目录要含有location指定名称的同名目录。另外,根据前文所述,使用alias标签的目录块中不能使用rewrite的break。

所以使用nginx设置root时要注意一个问题,就是如果该root设置的前端目录不是根目录,那么在写root的绝对地址时,要把前端目录的部分省略掉。
我们用设置虚拟目录指向的alias来和root比较一下就非常明显了

location /abc/ {     alias /home/html/abc/; }  

 

在这段配置下,http://test/abc/a.html就指定的是 /home/html/abc/a.html。这段配置亦可改成

location /abc/ {     root /home/html/;}  


 

可以看到,使用root设置目录的绝对路径时,少了/abc,也就是说,使用root来设置前端非根目录时,nginx会组合root和location的路径,即 /home/html/abc/。

另外,使用alias时目录名后面一定要加“/”

### NginxLocation块的配置 #### Location块的作用 Nginx中的`location`块用于定义针对特定URL路径的处理规则。通过这些规则,可以精确控制不同类型的请求如何被处理,包括静态文件服务、反向代理设置以及其他各种操作[^2]。 #### 配置语法与匹配原则 `location`指令接受两种主要形式来指定要匹配的URI模式: - **前缀字符串**:如果以普通字符开始,则表示简单的前缀匹配。 ```nginx location /images/ { root /var/www/site; } ``` - **正则表达式**:以波浪号(`~`)或感叹号加波浪号(`!~`)开头分别代表区分大小写和不区分大小写的PCRE兼容正则表达式的匹配方式 ```nginx location ~ \.(gif|jpg|png)$ { expires 30d; } ``` 为了提高性能,在多个可能的选择之间,优先级顺序如下: 1. 完全匹配(=) 2. 正则表达式按出现次序逐一测试直到找到第一个成功者 3. 最长前缀匹配;如果有两个以上的最长前缀相等长度,则最先声明的那个获胜 #### 实际应用案例 下面给出几个实际应用场景下的例子说明如何利用`location`实现不同的功能需求: ##### 提供静态资源 假设网站根目录位于 `/usr/share/nginx/html`, 而图片存放在子目录 `img` 下面, 则可以通过以下方式快速定位并返回给客户端请求的内容. ```nginx server { ... location /img/ { alias /usr/share/nginx/html/img/; } } ``` ##### 设置缓存策略 对于某些类型的文件(如CSS, JavaScript), 可以为它们设定较长的有效期以便浏览器能够更好地缓存从而减少重复加载时间. ```nginx location ~* \.(css|js)$ { add_header Cache-Control "public, max-age=86400"; } ``` ##### 使用反向代理转发请求到后端服务器 当涉及到动态页面生成或其他复杂业务逻辑时,通常会选择将这类工作交给专门的应用程序服务器完成。此时就可以借助于`proxy_pass`命令把符合条件的HTTP请求转交给后台的服务实例去执行具体的任务. ```nginx location /api/ { proxy_pass http://localhost:9000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值