千家信息网

Nginx——Rewrite及nginx模块(理论篇)

发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,Rewrite跳转场景URL看起来更规范,合理企业会将动态URL地址伪装成静态地址提供服务网址换新域名后,让旧的访问跳转到新的域名上服务端某些业务调整Rewrite跳转实现Rewrite实用场景Ngi
千家信息网最后更新 2025年01月22日Nginx——Rewrite及nginx模块(理论篇)

Rewrite跳转场景

URL看起来更规范,合理企业会将动态URL地址伪装成静态地址提供服务网址换新域名后,让旧的访问跳转到新的域名上服务端某些业务调整

Rewrite跳转实现

Rewrite实用场景

  • Nginx跳转需求的实现方式
    使用rewrite进行匹配跳转
    使用if匹配全局变量后跳转
    使用location匹配再跳转
  • rewrite放在server{},if{},location{}段中
  • 对域名或参数字符串
    使用if全局变量匹配
    使用proxy_pass反向代理

常用的正则表达式元字符

字符说明
^匹配输入字符串的起始位置
$匹配输入字符串的结束位置
*匹配前面的字符零次或多次
+匹配前面的字符一次或多次
匹配前面的字符零次或一次
.匹配除\n之外的任何单个字符,使用诸如"[.\n]"之类的模式,可匹配包括"\n"在内的任意字符
\d匹配纯数字 [0-9]
{n}重复多次
{n,}重复n次或更多次
[c]匹配单个字符c
[a-z]匹配a-z小写字母的任意一个
[a-zA-Z]匹配a-z小写字母或A-Z大写字母的任意一个

Rewrite命令

语法:rewrite                          [flag];            正则                  跳转后的内容               rewrite支持的flag标记

flag标记说明:

标记说明
last相当于Apache的[L]标记,表示完成rewrite
break本条规则匹配完成即终止,不再匹配后面的任何规则
redirect返回302临时重定向,浏览器地址会显示跳转后的URL地址,爬虫不会更新url
permanent返回301永久重定向,浏览器地址栏会显示跳转后的URL地址,爬虫更新url

last和break比较:

lastbreak
使用场景一般写在server和if中一般使用在location中
URL匹配不终止重写后的url匹配终止重写后的url匹配

location分类

分类:    location = patt {} [精准匹配]    location patt {} [一般匹配]    location ~ patt {} [正则匹配]

正则匹配的常用表达式:

标记说明
~执行一个正则匹配,区分大小写
~*执行一个正则匹配,不区分大小写
!~执行一个正则匹配,区分大小写不匹配
!~*执行一个正则匹配,不区分大小写不匹配
^~普通字符匹配;使用前缀匹配。如果匹配成功,则不再匹配其他location
=普通字符精准匹配。也就是完全匹配
@定义一个命名的location,使用在内部定向时

location优先级

**相同类型的表达式,字符创长的会优先匹配****按优先级排列**    = 类型    ^~ 类型表达式    正则表达式(~和~*)类型    常规字符串匹配类型,按前缀匹配    通常匹配(/),如果没有其他匹配,任何请求都会匹配到

比较rewrite和location

**相同点**        都能实现跳转**不同点**        rewrite是在同一域名内更改获取资源的路径        location是对一类路径做控制访问或方向代理,还可以proxy_pass到其他机器**rewrite会写在location里执行顺序**        执行server块里面的rewrite指令        执行location匹配        执行选定的location中的rewrite指令

location优先级的示例

##精确匹配/,主机名后面不能带任何字符串location = / {[ configuration A ]     }##所有的地址都以/开头,这条规则将匹配到所有请求,但正则和最长字符串会优先匹配location  / {[ configuration B ]     }##匹配任何以/documents/开头的地址,当后面正则表达式没有匹配到时,才起作用location /documents/ {[ configuration C ]}##匹配任何以/documents/abc开头的地址,当后面正则表达式没有匹配到时,才会起作用location ~ /documents/abc {[ configuration D ]}##以/images/开头的地址,匹配符合后,停止往下匹配location ^~ /images/ {[ configuration E ]}##匹配所有以gif结尾的请求,/images/下的图片会被[configuration E]处理,因为^~的优先级更高location ~* \.(gif|jpg|jpeg)$ {[ configuration F ]}##最长字符匹配到/images/abc,优先级最低location /images/abc {[ configuration G ]}##以/images/abc开头的,优先级次之location ~ /images/abc {[ configuration H ]}##如果和正则~/images/abc/1.html相比,正则优先级更高location /images/abc/1.html {[ configuration I ]}

location优先级规则

Nginx模块

1,Nginx 工作原理

Nginx 由内核和模块组成。
 Nginx 本身做的工作实际很少,当它接到一个 HTTP 请求时, 它仅仅是通过查找配置文件将此次请求映射到一个 location block,而此 location 中所配 置的各个指令则会启动不同的模块去完成工作,因此模块可以看做 Nginx 真正的劳动工作者。

 通常一个 location 中的指令会涉及一个 handler 模块和多个 filter 模块(当然,多个 location 可以复用同一个模块)。handler 模块负责处理请求,完成响应内容的生成,而 filter 模块对响应内容进行处理。 用户根据自己的需要所开发的模块都属于第三方模块。正是有了这么多模块的支撑, Nginx 的功能才会如此强大。
Nginx 的模块从结构上分为核心模块、基础模块和第三方模块
核心模块:HTTP 模块、EVENT 模块和 MAIL 模块;
基础模块:HTTP Access 模块、HTTP FastCGI 模块、HTTP Proxy 模块和 HTTP Rewrite 模块;
第三方模块:HTTP Upstream Request Hash 模块、Notice 模块和 HTTP Access Key 模 块。
Nginx 的模块从功能上分为如下三类:
  Handlers(处理器模块):此类模块直接处理请求,并进行输出内容和修改 headers 信息等操作。Handlers 处理器模块一般只能有一个; Filters(过滤器模块):此类模块主要对其他处理器模块输出的内容进行修改操作,最后由 Nginx 输出; Proxies(代理类模块):此类模块是 Nginx 的 HTTP Upstream 之类的模块,这些模块主要与后端一些服务比如 FastCGI 等进行交互,实现服务代理和负载均衡等功能。

2. Nginx 的进程模型 在工作方式上,Nginx 分为单工作进程和多工作进程两种模式。

 在单工作进程模式下,除主进程外,还有一个工作进程,工作进程是单线程的;
 在多工作进程模式下,每个工作进程包含多个线程。Nginx 默认为单工作进程模式。

 Nginx 在启动后,会有一个 master 进程和多个 worker 进程。
 master 进程主要用来管理 worker 进程,主要包含:接收来自外界的信号,向各 worker 进程发送信号,监控 worker 进程的运行状态,当 worker 进程退出后(异常情况下),会自动 重新启动新的 worker 进程。 master 进程充当整个进程组与用户的交互接口,同时对进程进行监护。它不需要处理网络事件,不负责业务的执行,只会通过管理worker 进程来实现重启服务、平滑升级、更换日志文件、配置文件实时生效等功能。

3.Nginx+FastCGI运行原理

 Nginx 不支持对外部程序的直接调用或者解析,所有的外部程序(包括 PHP)必须通过FastCGI 接口来调用。FastCGI 接口在 Linux 下是 socket(这个 socket 可以是文件 socket, 也可以是 ip socket)。 wrapper 为了调用 CGI 程序,还需要一个 FastCGI 的 wrapper(wrapper 可以理解为用于启动另一个程序的程序),这个 wrapper 绑定在某个固定 socket 上,如端口或者文件 socket。当 Nginx 将 CGI 请求发送给这个 socket 的时候,通过 FastCGI 接口,wrapper 接收到请求,然后 Fork(派生)出一个新的线程,这个线程调用解释器或者外部程序处理脚本并读取返回数据;接着 wrapper 再将返回的数据通过 FastCGI 接口,沿着固定的 socket传递给 Nginx;最后 Nginx 将返回的数据(html 页面或者图片)发送给客户端。

谢谢阅读!

0