nginx

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > nginx > Nginx proxy、rewrite、alias配置

Nginx proxy、rewrite、alias配置过程

作者:无极之岚

这篇文章主要介绍了Nginx proxy、rewrite、alias配置过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Nginx proxy、rewrite、alias配置

proxy

一般解决跨域问题,使用Nginx进行proxy转发,也可以实现负载均衡。

# 代理根目录到内部应用
location / {
	proxy_pass http://127.0.0.1:8080;
}
# 代理模块到内部应用,可以带上后面拼接的路径,如果访问的是/order 则会进行一次301重定向,让浏览器访问/order/
location /order/ {
	proxy_pass http://127.0.0.1:8080/;
}
# 静态资源 
# 路径匹配 ^~为普通匹配,没有写也默认是普通匹配,所以可以不加
root /www/resources/static/;
location ^~ /static/ {
	root /www/resources/;
}
# 后缀,文件格式匹配
location ~*\.(gif|jpg|jpeg|png)${
	root /www/resources/;
}

location 的匹配取最长 最精确的那条。

rewrite

Nginx的rewrite模块即ngx_http_rewrite_module标准模块,主要功能是重写请求URI,也是Nginx默认安装的模块。

rewrite regrex replacement [flag]

匹配正则将其中regrex部分替换成replacement。而flag则表示替换的程度

为了避免一个请求经过两次WAF,又能实现转向到静态页面,用了 redirect重定向,让第二次请求由浏览器发出

location /download {
	rewrite /download index.html  redirect;
}

alias

vue的应用入口是index.html,打包后,访问nginx的80端口想要出这个网页,就需要配置alias

# 将/download请求 别名到/download/index.html页面,但是中间会发生一次301重定向重新访问/download/
location /download {
	index index.html;
	alias /static/;
}

静态资源别名

# 将/static/的文件都指向nginx 的/resource/static/文件夹
location /static/ {
	alias /resource/static/;
}

Nginx的proxy_pass、root、alias的说明

代理配置:

1、root

root配置代理路径时,会在代理的地址后拼接配置字段:

location /static {
        root static/image;
}

在访问http://ip:port/static/*.*时会映射到http://ip:port/static/static/image/*.*

2、alias(只能用于location)

alias配置代理路径时,直接替换代理地址:

location /static {
         alias static/image;
}

在访问http://ip:port/static/*.*时会映射到http://ip:port/static/image/*.*

3、proxy_pass

proxy_pass配置代理路径时,直接替换整个代理路径,包括ip地址的端口等:

location /static {
        proxy_pass http://ip_two:port_two/static;
}

在访问http://ip:port/static/*.*时会映射到http://ip_two:port_two/static/static/*.*

代理路径后不带斜杠时,配置路径会替代原本的ip和端口等,并拼接代理地址。

代理路径后带斜杠时,配置路径会替代原本的ip和端口等,不拼接代理地址。

location /static/ {
        proxy_pass http://ip_two:port_two/abc/;
}

在访问http://ip:port/static/*.*时会映射到http://ip_two:port_two/abc/*.*

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文