Nginx proxy、rewrite、alias配置过程

 更新时间:2024年06月04日 15:27:02   作者:无极之岚  
这篇文章主要介绍了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则表示替换的程度

  • last匹配成功后,其余匹配不执行(可以重写多个)直接用新的URI进行下一跳,也会为新的URI进行location匹配。
  • break停止rewrite的相关指令,但不进行location跳转。重写后的请求在一个location域中跳转。可能会有人觉得没啥用,但是有些场景就是需要在url上增加一个参数但页面不做显式刷新
  • redirect响应请求头返回302,重写浏览器uri并进行临时重定向
  • permanent响应请求头返回301,重写浏览器uri并进行永久重定向

为了避免一个请求经过两次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/*.*

总结

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

相关文章

  • 负载均衡的基本知识以及使用nginx进行负载均衡的简单例子

    负载均衡的基本知识以及使用nginx进行负载均衡的简单例子

    今天小编就为大家分享一篇关于负载均衡的基本知识以及使用nginx进行负载均衡的简单例子,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • Nginx配置统计流量带宽请求及记录实时请求状态的方法

    Nginx配置统计流量带宽请求及记录实时请求状态的方法

    这篇文章主要介绍了Nginx中配置统计流量带宽请求及记录实时请求状态的方法,分别用到了ngx_req_status和ngx_realtime_request模块,需要的朋友可以参考下
    2016-01-01
  • Nginx ssi合并页面的具体实现

    Nginx ssi合并页面的具体实现

    nginx的ssi模块是一种类似于ASP的基于服务器的网页制作技术,本文主要介绍了Nginx ssi合并页面的具体实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-05-05
  • nginx部署多前端项目的几种方法

    nginx部署多前端项目的几种方法

    最近一台服务器要配置多个前端项目,个人总结了3种方法来实现在一台服务器上使用nginx部署多个前端项目的方法。需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05
  • nginx信号集案例详解

    nginx信号集案例详解

    本篇内容给大家详细分析一下nginx信号集相关知识以及实例中的问题分析,一起学习参考下。
    2017-11-11
  • nginx反向代理的全流程

    nginx反向代理的全流程

    这篇文章主要介绍了nginx反向代理的全流程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Nginx部署SSL证书的过程

    Nginx部署SSL证书的过程

    SSL证书是数字证书的一种,类似于驾驶证、护照和营业执照的电子副本,这篇文章主要介绍了Nginx部署SSL证书的相关知识,需要的朋友可以参考下
    2022-10-10
  • nginx的请求转发配置过程

    nginx的请求转发配置过程

    Nginx在Windows和Linux环境下的安装、启动、停止、配置和请求转发过程,配置文件语法检测、优雅关闭、热部署和日志文件重新打开,配置多个服务的请求转发规则,修改前端API地址,设置最大上传文件大小
    2024-12-12
  • CentOS 7下编译安装Nginx 1.11.10教程

    CentOS 7下编译安装Nginx 1.11.10教程

    这篇文章主要介绍了在CentOS 7下编译安装Nginx 1.11.10的方法,文中给出了详细的安装步骤,相信对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-03-03
  • Nginx批量添加二级子域名完美方案

    Nginx批量添加二级子域名完美方案

    这篇文章主要介绍了Nginx批量添加二级子域名完美方案,本文讲解使用正则表达式批量匹配指定域名的二级域名虚拟主机,需要的朋友可以参考下
    2015-04-04

最新评论