文章目录
前言
write的组要功能是实现RUL地址的重定向。Nginx的rewrite功能需要PCRE软件的支持,即通过perl兼容正则表达式语句进行规则匹配的。默认参数编译nginx就会支持rewrite的模块,但是也必须要PCRE的支持
Rewrite
- URL看起来更规范、合理
- 企业会将动态URL地址伪装成静态地址提供服务
- 网址换新域名后,让旧的访问跳转到新的域名上
- 服务端某些业务调整
Rewrite实用场景
Nginx跳转需求的实现方式3种
- 使用 rewrite进行匹配跳转
- 使用if匹配全局变量后跳转
- 使用 location匹配再跳转
rewrite放在 server{},if{}, location{} 段中
对域名或参数字符串
- 使用if全局变量匹配
- 使用 proxy_pass反向代理
Nginx正则表达式(又有正则了啊)
字符 | 说明 |
---|---|
^ | 匹配输入字符串的起始位置 |
$ | 匹配输入字符串的结束位置 |
* | 匹配前面的字符零次或多次 |
+ | 匹配前面的字符一次或多次 |
? | 匹配前面的字符零次或一次 |
. | 匹配除"\n"之外的任何单个字符===>使用诸如"【.\n】“之类的模式,可匹配包括”\n"在内的任意字符 |
\ | 将后面接着的字符标记为一个特殊字符或一个原义字符或一个向后引用 |
\d | 匹配纯数字 |
{n} | 重复n次 |
{n,} | 重复n次或更多次 |
[c] | 匹配单个字符c |
[a-z] | 匹配a-z小写字符的任意一个 |
[a-zA-Z] | 匹配a-z小写字母或A-Z大写字母的任意一个 |
Rewrite命令
Rewrite命令语法
flag标记说明
标记 | 说明 |
---|---|
last | 相当于Apache的[L]标记,表示完成rewrite |
break | 本条规则匹配完成即终止,不再匹配后面的任何规则 |
redirect | 返回302临时重定向,浏览器地址会显示跳转后的URL地址,爬虫不会更新url |
permanent | 返回301永久重定向,浏览器地址栏会显示跳转后的URL地址,爬虫更新url |
last和break比较有什么不同?
Location模块
location有哪些分类?
- location = patt {} [精准匹配]
- ocation patt {} [一般匹配 ]
- location ~ patt {} [正则匹配]
正则匹配
标记 | 说明 |
---|---|
~ | 执行一个正则匹配,区分大小写 |
~* | 执行一个正则匹配,不区分大小写 |
!~ | 执行一个正则匹配,区分大小写不匹配 |
!~* | 执行一个正则匹配,不区分大小写不匹配 |
^~ | 普通字符批评日;使用前缀匹配.如果匹配成功,则不再匹配其他location |
= | 普通字符精确匹配,也就是完全能匹配 |
@ | 定义一个命名的location,使用在内部定向时 |
location的优先级
- 相同类型的表达式,字符串长的会优先匹配
- 按优先级排列
- = 类型
- ^~ 类型表达式
- 正则表达式 (和*)类型
- 常规字符串匹配类型,按前缀匹配
- 通用匹配(/),如果没有其他匹配,任何请求都会匹配到
location优先级规则
- 匹配某个具体文件
- ( location = 完整路径)>( location ^~ 完整路径)>( location ~* 完整路径)>( location ~ 完整路径)>( location完整路径)>( location /)
- 用目录做匹配访问某个文件
- ( location = 目录)>( location ^~ 目录)>( location ~ 目录)>
( location ~* 目录)>( location 目录)>( location /)
- ( location = 目录)>( location ^~ 目录)>( location ~ 目录)>
location优先级的示例
location = / { //精确匹配 /,主机名后面不能带任何字符串'
[configuraion A ]
}
location / { //所有的地址都以/开头,这条规则将匹配到所有请求,但正则和最长字符串会优先匹配'
[configuraion B ]
}
location /documents/ { //匹配任何以/documents/开头的地址,当后面的正则表达式没有匹配到时,才起作用'
[configuraion C ]
}
location ~ /documents/abc { //匹配任何以/documents/abc开头的地址,当后面的正则表达式没有匹配到时,才会起作用'
[configuraion D ]
}
location ^~ /images/ { //以/images/开头的地址,匹配符合后,停止往下匹配'
[configuraion E ]
}
location ~*\.(gif|jpg|gpeg)$ { '//匹配所有以 gif, jpg或jpeg结尾的请求, Images/下的图片会被 [configuration E]处理,因为^~的优先级更高'
[configuraion F ]
}
location /images/abc { '//最长字符匹配到 /images/abc,优先级最低'
[configuraion G ]
}
location ~ /images/abc { '//以/ Images/abc开头的,优先级次之'
[configuraion H ]
}
location /images/abc/1.html { '//如果和正则 ~ images/abc/1.htm相比,正则优先级更高'
[configuraion I ]
}
rewrite和 location有什么不同?
- 相同点
- 都能实现跳转
- 不同点
- rewrite是在同一域名内更改获取资源的路径
- location是对一类路径做控制访问或反向代理,还可以 proxy_pass到其他机器
- write会写在 location里,执行顺序
- 执行 server块里面的 rewrite指令
- 执行 location匹配
- 执行选定的 location中的 rewrite指令
实验
基于域名跳转
需求:公司旧域名,www.kgc.com,因业务需求有变更,需要使用新域名www.nekgc.com代替,不能废除旧域名,从旧域名跳转到新域名,且保持其参数不变
安装nginx的源码地地址(安装这个才可以yum安装nginx)
[root@promote ~]# rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
[root@promote conf.d]# yum -y install nginx
配置DNS
[root@promote nginx]# yum -y install bind
[root@promote conf.d]# vim /etc/named.conf
修改2个any
[root@promote conf.d]# vim /etc/named.rfc1912.zones
zone "kgc.com" IN {
type master;
file "kgc.com.zone";
allow-update { none; };
};
zone "newkgc.com" IN {
type master;
file "newkgc.com.zone";
allow-update { none; };
};
[root@promote conf.d]# cd /var/named/
[root@promote named]# cp -p named.loopback kgc.com.zone
[root@promote named]# vim kgc.com.zone
www IN A 192.138.136.88
[root@promote named]# cp -p kgc.com.zone newkgc.com
写入DNS解析器中
[root@promote named]# echo "namedserver 192.168.136.88" > /etc/resolv.conf
开启服务
[root@promote named]# systemctl restart named
检查解析是否成功
[root@promote named]# nslookup www.kgc.com
Server: www.kgc.com
Address: 192.168.136.88
配置nginx跳转服务
[root@promote nginx]# vim/etc/nginx/conf.d/ default.conf
listen 80;
server_name www.kgc.com;
access_log /var/log/nginx/host.access.log main;
配置二 添加跳转
location / {
if ($host = "www.kgc.com") { //添加
rewrite ^/(.*)$ http://www.newkgc.com/$1 permanent;
}
^/(.*)$ 表示除了前面域名以外。后面的文件名目录都匹配
开服务
[root@promote html]# systemctl restart nginx
查看是否开启
[root@promote named]# netstat -ntap | grep nginx
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 12804/nginx: master
[root@promote named]# netstat -ntap | grep named
tcp 0 0 192.168.136.88:53 0.0.0.0:* LISTEN 12551
打开浏览器输入www.kgc.com回车,可以发现浏览器会自动跳转到www.newkgc.com上
基于客户端IP跳转
需求
公司今天业务上线,所有IP地址访问任何内容都有一个固定的维护页面,只有公司IP访问正常
(.+)表示域名后面的子目录
#charset koi8-r;
access_log /var/log/nginx/host.access.log main;
set $rewrite true;
if ($remote_addr = "192.168.136.123"){ //公司内部网站为合法网址
set $rewrite false;
}
if ($rewirte = true) { 非法ip打上标记
rewrite (.+) /error.html;
}
location = /error.html { 配置标记进行跳转站点
root /usr/share/nginx/html;
}
配置错误页面
[root@localhost html]# cd /usr/share/nginx/html/
[root@localhost html]# vim main.html
<h1>this is text web </h1>
开启服务
[root@promote html]# systemctl restart nginx
在客户机上清除浏览器缓存后再次访问站点www.kgc.com可以发现跳转的是刚才写入的error.html中的内容
修改成正确的地址就可以访问
基于旧、新域名跳转并加上目录
需求:将域名下面的发帖全部都跳转到,且域名跳转后保持参数不变
[root@localhost ~]# vim /etc/nginx/conf.d/default.conf ## 编辑配置文件
server {
listen 80;
server_name bbs.kgc.com; 修改网址
#charset koi8-r;
access_log /var/log/nginx/host.access.log main;
location /post { //添加
rewrite (.+) http://www.kgc.com/bbs$1 permanent;
}
添加新域名
[root@localhost named]# vim kgc.com.zone
bbs IN A 192.168.136.40
重启DNS及nginx服务
[root@localhost html]# systemctl restart named
[root@localhost html]# systemctl restart nginx
四 基于参数匹配的跳转
[root@localhost ~]# vim /etc/nginx/conf.d/default.conf
if ($request_uri ~ ^/100-(100|200|300)-(\d+).html$) {
rewrite (.*) http://www.test.com permanent;
}
五 基于所有php文件的跳转
[root@localhost ~]# vim /etc/nginx/conf.d/default.conf
location ~* /upload/.*\.php$ {
rewrite (.+) http://www.test.com permanent;
}
基于最普通的一条url请求的跳转,访问一个具体的页面跳转到首页
[root@localhost ~]# vim /etc/nginx/conf.d/default.conf
location ~* ^/aaa/error.html {
rewrite (.+) http://www.test.com permanent;
}