当运维遇到要重写情况时,往往是要程序员把重写规则写好后,发给你,你再到生产环境下配置。对于重写规则说到底就是正则匹配,做运维的岂能对正则表达式不了解的?最起码最基本的正则表达式会写。套用一句阿里的话(某网友说是阿里说的,不清楚到底是不是出自阿里)“不懂程序的运维,不是好运维;不懂运维的开发,不是好开发。”。 正则表达式也是一门语言哈。当你学习一门语言时,必然会遇到该门语言的正则表达式这章节的。 在这里推荐一本非常好的正则表达式书,包含常用的语言的正则写法如sed、perl、bash、awk、php、c#、java、javascript、python、ruby等等,《Regular Expressions Cookbook, 2nd Edition》,也有中文版的,大家可以到网络上找找。
本文介绍nginx的重写模块,创建重写规则向导,便于快捷正确的创建新的重写规则,不求救于人。同时,如果想把apache转换成nginx,重写规则也是要改的咯。
一. rewrite模块介绍
nginx的重写模块是一个简单的正则表达式匹配与一个虚拟堆叠机结合。依赖于PCRE库,因此需要安装pcre。根据相关变量重定向和选择不同的配置,从一个location跳转到另一个location,不过这样的循环最多可以执行10次,超过后nginx将返回500错误。同时,重写模块包含set指令,来创建新的变量并设其值,这在有些情景下非常有用的,如记录条件标识、传递参数到其他location、记录做了什么等等。
二. rewrite模块指令
break
语法:break
默认值:none
使用字段:server, location, if
完成当前设置的重写规则,停止执行其他的重写规则。
if
语法:if (condition) { … }
默认值:none
使用字段:server, location
注意:尽量考虑使用try_files代替。判断的条件可以有以下值:
- 一个变量的名称:空字符传“”或者一些“0”开始的字符串为false。
- 字符串比较:使用=或!=运算符
- 正则表达式匹配:使用~(区分大小写)和~*(不区分大小写),取反运算!~和!~*。
- 文件是否存在:使用-f和!-f操作符
- 目录是否存在:使用-d和!-d操作符
- 文件、目录、符号链接是否存在:使用-e和!-e操作符
- 文件是否可执行:使用-x和!-x操作符
return
语法:return code
默认值:none
使用字段:server, location, if
停止处理并为客户端返回状态码。非标准的444状态码将关闭连接,不发送任何响应头。可以使用的状态码有:204,400,402-406,408,410, 411, 413, 416与500-504。如果状态码附带文字段落,该文本将被放置在响应主体。相反,如果状态码后面是一个URL,该URL将成为location头补值。没有状态码的URL将被视为一个302状态码。
rewrite
语法:rewrite regex replacement flag
默认值:none
使用字段:server, location, if
按照相关的正则表达式与字符串修改URI,指令按照在配置文件中出现的顺序执行。可以在重写指令后面添加标记。
注意:如果替换的字符串以http://开头,请求将被重定向,并且不再执行多余的rewrite指令。
尾部的标记(flag)可以是以下的值:
- last – 停止处理重写模块指令,之后搜索location与更改后的URI匹配。
- break – 完成重写指令。
- redirect – 返回302临时重定向,如果替换字段用http://开头则被使用。
- permanent – 返回301永久重定向。
rewrite_log
语法:rewrite_log on | off
默认值:rewrite_log off
使用字段:server, location, if
变量:无
启用时将在error log中记录notice级别的重写日志。
set
语法:set variable value
默认值:none
使用字段:server, location, if
为给定的变量设置一个特定值。
uninitialized_variable_warn
语法:uninitialized_variable_warn on|off
默认值:uninitialized_variable_warn on
使用字段:http, server, location, if
控制是否记录未初始化变量的警告信息。
三. 重写规则组成部分
3.1 任何重写规则的第一部分都是一个正则表达式
可以使用括号来捕获,后续可以根据位置来将其引用,位置变量值取决于捕获正则表达式中的顺序,$1引用第一个括号中的值,$2引用第二个括号中的值,以此类推。如:
1 |
^/images/([a-z]{ 2 })/([a-z0- 9 ]{ 5 })/(.*)\.(png|jpg|gif)$
|
$1是两个小写字母组成的字符串,$2是由小写字母和0到9的数字组成的5个字符的字符串,$3将是个文件名,$4是png、jpg、gif中的其中一个。
3.2 重写规则的第二部分是URI
请求被改写。该URI可能包含正则表达式中的捕获的位置参数或这个级别下的nginx任何配置变量。如:
1 |
/data?file=$ 3 .$ 4
|
如果这个URI不匹配nginx配置的任何location,那么将给客户端返回301(永久重定向)或302(临时重定向)的状态码来表示重定向类型。该状态码可以通过第三个参数来明确指定。
3.3 重写规则的第三部分
第三部分也就是尾部的标记(flag)。 last标记将导致重写后的URI搜索匹配nginx的其他location,最多可循环10次。如:
1 |
rewrite '^/images/([a-z]{2})/([a-z0-9]{5})/(.*)\.(png|jpg|gif)$' /data?file=$ 3 .$ 4 last;
|
break指令可以当做自身指令。如:
1
2 3 4 |
if ($bwhog) {
|
另一个停止重写模块处理指令是return, 来控制主HTTP模块处理请求。 这意味着,nginx直接返回信息给客户端,与error_page结合为客户端呈现格式化的HTML页面或激活不同的模块来完成请求。如果状态码附带文字段落,该文本将被放置在响应主体。相反,如果状态码后面是一个URL,该URL将成为location头补值。没有状态码的URL将被视为一个302状态码。如:
1
2 3 |
location = /image404.html {
|
四. 实例
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
http {
|
五. 创建新的重新规则
在接到要创建新的重写规则时,要弄清楚需求是什么样的,再决定怎么做。毕竟重写也是耗资源的有效率之分的。 下面的这些问题有些帮助的:
- 你的URL的模式是什么样的?
- 是否有一个以上的方法来实现?
- 是否需要捕获URL部分作为变量?
- 重定向到另一个web上可以看到我的规则?
- 是否要替换查询的字符串参数?
检查网站或应用程序布局,清楚URL模式。啰嗦一句:我一而再再而三的强调,运维不能与开发脱节,运维要参与到开发当中。如果有不止一种方法实现,创建一个永久重定向。同时,定义一个重写规范,来使网址清洁,还可以帮助网站更容易被找到。
实例1. 要将home目录重定向到主页面上,目录结构如下:
1
2 3 4 5 6 7 8 |
/
|
重写规则如下:
1
2 |
rewrite ^/(home(/index)?|index(\.php)?)/?$ $scheme:
|
指定$scheme和$host变量,因为要做一个永久重定向并希望nginx使用相同的参数来构造URL。
实例2. 如果想分别记录各个部分的URL,可以使用正则表达式来捕获URI,然后,给变量分配指定位置变量,见上面的实例。
实例3. 当重写规则导致内部重定向或指示客户端调用该规则本身被定义的location时,必须采取特殊的动作来避免重写循环。如:在server配置段定义了一条规则带上last标志,在引用location时,必须使用break标志。
1
2 3 4 5 6 |
server {
|
实例4. 作为重写规则的一部分,传递新的查询字符串参数是使用重写规则的目标之一。 如:
1 |
rewrite ^/images/(.*)_(\d+)x(\d+)\.(png|jpg|gif)$ /resizer/$ 1 .$ 4 ?width=$ 2 &height=$ 3 ? last;
|
nginx重写规则说起来挺简单的,做起来就难,重点在于正则表达式,同时,还需要考虑到nginx执行顺序。
http://www.techug.com/85916-2
相关推荐
《Nginx权威指南》是一本深度探讨Nginx服务器配置、优化以及故障排查的专业书籍。Nginx作为一款高性能的HTTP和反向代理服务器,因其高效、稳定和易扩展的特性,在全球范围内广泛应用于各类网站和应用的前端。本指南...
- **重写规则**:理解Nginx的rewrite模块,编写URL重写规则,实现URL美化和SEO优化。 5. **SSL/TLS安全** - **HTTPS配置**:配置Nginx支持HTTPS,理解和使用SSL证书,确保网站通信安全。 - **HSTS与OCSP**:了解...
11. Nginx重写规则指南:Nginx的rewrite模块提供了URL重写功能,可以按照一定规则重定向或修改请求的URI。 12. Nginx逻辑运算:Nginx配置中可以使用逻辑运算符来编写条件判断。 13. 隐藏Nginx版本号:隐藏版本号...
#### 九、Nginx 重写规则指南 - **Rewrite 模块介绍**:了解 Nginx 的 rewrite 模块及其作用。 - **Rewrite 模块指令**:掌握 `rewrite` 指令的基本用法。 - **重写规则组成部分**:包括匹配模式、目标 URL、标志位...
Nginx 使用指南 一. Nginx 基础知识 Nginx 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。Nginx 的主要特性包括处理静态文件、索引文件和自动索引、无缓存的反向代理加速、简单的...
9. Nginx重写规则指南:Nginx的rewrite模块可以用于修改请求的URI,通过正则表达式重写规则可以实现复杂的URL处理逻辑。 10. Nginx逻辑运算:Nginx配置文件中可以使用逻辑运算符,如"!"表示逻辑非,"||"表示逻辑或...
以上是对《Nginx应用技术指南》中的主要知识点进行了详细的总结和扩展,涵盖了Nginx的基础知识、安装配置、优化技巧、URL分发、重写规则、访问控制、日志处理等多个方面,旨在帮助读者全面掌握Nginx的应用技巧和最佳...
### Nginx应用技术指南知识点解析 #### 一、Nginx基础知识 **1.1 简介** Nginx是一款开源的Web服务器和反向代理服务器,由Igor Sysoev为俄罗斯大型网站Rambler.ru设计,旨在解决传统Web服务器在高并发连接下性能...
- **处理模块(非代理)**:处理模块负责直接处理客户端请求,通常用于静态文件服务、重写规则等。处理模块需要获取位置配置结构体,生成并发送HTTP响应。 - **上游模块(代理模块)**:代理模块用于将请求转发给后端...
同时,Nginx提供了多个可用的全局变量来作为条件判断,使得URL重写规则更加灵活和强大。 Nginx的重定向功能包括基于域名、URL路径的301、302重定向,以及对特定请求的拒绝和拦截。 日志处理也是Nginx管理的重要...
Nginx的Rewrite功能是基于特定规则对URL进行重写,是实现复杂的URL处理逻辑的重要手段。Rewrite规则可以通过基本标记(flags)来控制,可以使用正则表达式匹配,文件及目录匹配,还可以利用Nginx内置的一些全局变量...
Nginx有许多可选模块,如access_log记录访问日志、gzip压缩内容以减少网络传输、rewrite实现URL重写规则、proxy_pass用于反向代理等。根据实际需求,选择合适的模块进行编译安装。 **Nginx内置变量** Nginx提供丰富...
5. URL重写与重定向:Nginx提供了强大的URL重写和重定向功能,可以通过配置规则改变请求的URL,适用于SEO优化、维护和负载均衡等。 6. 缓存管理:Nginx可以作为缓存服务器使用,能够缓存静态内容以减少后端服务器的...
Rewrite模块允许Nginx根据预定义的规则重写URL,这对于URL美化、SEO优化和URL重定向非常有用。 **Nginx Redirect** Redirect指令用于将请求重定向到其他URL,可以实现临时或永久的URL改变。 **Nginx Location** ...
PCRE是NginX的URL重写模块所必需的。 3. 切换到`nginx-1.1.11`目录,使用以下命令配置NginX: ``` ./configure --prefix=/usr/local/Nginx --with-http_stub_status_module ``` `--prefix`选项指定安装路径,`-...
Nginx 官方文档中文版知识点总结 Nginx 是一个开源的 Web 服务器软件,可以作为 Web 服务器、反向代理服务器、缓存服务器、负载均衡器和媒体流服务器等。...* 转换重写规则 * WebSocket 代理 * 开发贡献指南
Nginx的`rewrite`模块允许设置复杂的URL重写规则,这对于SEO优化和实现RESTful API设计非常重要。规则可以基于正则表达式,结合`break`、`last`、`redirect`和`permanent`等标志来控制重写的逻辑。 6. **HTTP缓存...
本资料包包含了《Nginx模块开发指南》和《深入理解Nginx》等资源,旨在帮助初学者逐步探索Nginx的设计思想和内部机制。 **1. Nginx的设计理念** Nginx采用事件驱动的异步非阻塞模型,这种模型使得它在处理大量并发...