服务器群集——Nginx Rewrite

一、Nginx Rewrite概述

1、Rewrite跳转场景

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

2、Rewrite跳转实现

ngx_ http. rewrite module

  • Nginx 支持URL重写支持l条件判断,但不支持else
  • 跳转 循环最多可以执行10次)超过后nginx将返回500错误
  • PCRE支持
  • 重写模块set指令
    rewrite使用Nginx全局变量或自己设置的变量,结合正则表达式和标志位实现URL重写以及重定向

3、Rewrite实际场景

1、Nginx跳转需求的实现方式

  • 使用rewrite进行匹配跳转
  • 使用if匹配全局变量后跳转
  • 使用location匹配再跳转
    2、rewrite放在server{}, if{}, location{} 段中
  • location只对域名后边的除去传递参数外的字符串起作用,Location只匹配关键字段
    3、对域名或参数字符串
  • 使用if全局变量匹配
  • 使用proxy_ pass反向代理

二、Nginx正则表达式

1、常用的正则表达式元字符

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

2、Rewrite命令

1、Rewrite命令语法

rewrite     <regex>     <replacement>    [lag];
             正则       跳转后的内容     rewrite支持的flag标记

2、flag标记说明

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

last和break比较

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

三、location分类

1、分类

location = patt {} [精准匹配]
location patt {} [-般匹配]
location ~ patt 0 [正则匹配]

2、正则匹配的常用表达式

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

3、location优先级

1、相同类型的表达式,字符串长的会优先匹配
2、按优先级排列

  • =类型
  • ^~类型表达式
  • 正则表达式(*)类型
  • 常规字符串匹配类型,按前缀匹配
  • 通用匹配(/) ,如果没有其它匹配,任何请求都会匹配到

4、比较rewrite和location

相同点

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

5、location优先级规则

1、匹配某个具体文件
(location =完整路径) > (location ^~完整路径) > (location ~*完整路径) > (location ~完整路径) > (location 完整路径) >(location /)
2、用目录做匹配访问某个文件
(location=目录) > (location ^~目录/) > (location~目录) >(location ~*目录) > (location 目录) > (location 1)

四、实验

安装nginx服务
1.安装nginx源
rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
2.安装nginx软件包
yum install -y nginx
3.修改默认站点配置文件:etc/nginx/conf.d/default.conf
server {
listen
80;
server_ name www.domain.com;
#charset koi8-r;
acess_ log warlog/nginx/www. domain.com-access log main;
location/{
root /usr/share/nginx/html;
index index. html index .htm;
…省略部分
5/2t
4.启动nginx
注意

  • 确定域名可以正常解析
  • 做下一个场景前,要删除上一个场景的配置
  • 及时清除浏览器缓存

1、基于域名跳转,旧域名跳转新域名

公司旧域名www.kgc.com,因业务需求有变更,需要使用新域名www.newkgc.com代替

  • 不能废除旧域名
  • 从旧域名跳转到新域名,且保持其参数不变
[root@localhost ~]# iptables -F
[root@localhost ~]# setenforce 0
[root@localhost ~]# rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
[root@localhost ~]# yum install -y nginx
[root@localhost ~]# rpm -q nginx     //查看是否安装
nginx-1.18.0-1.el7.ngx.x86_64
[root@localhost ~]# rpm -qc nginx    //查看各个文件安装位置
/etc/logrotate.d/nginx
/etc/nginx/conf.d/default.conf
/etc/nginx/fastcgi_params
/etc/nginx/koi-utf
/etc/nginx/koi-win
/etc/nginx/mime.types
/etc/nginx/nginx.conf
/etc/nginx/scgi_params
/etc/nginx/uwsgi_params
/etc/nginx/win-utf
/etc/sysconfig/nginx
/etc/sysconfig/nginx-debug
[root@localhost ~]# cd /etc/nginx/
[root@localhost nginx]# ls
conf.d          koi-utf  mime.types  nginx.conf   uwsgi_params
fastcgi_params  koi-win  modules     scgi_params  win-utf
[root@localhost nginx]# cd conf.d/
[root@localhost conf.d]# vim default.conf 
[root@localhost conf.d]# yum -y install bind   
[root@localhost conf.d]# vim /etc/named.conf 
options {
        listen-on port 53 { any; };
allow-query     { any; };
[root@localhost 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@localhost conf.d]# cd /var/named/
[root@localhost named]# ls
data  dynamic  named.ca  named.empty  named.localhost  named.loopback  slaves
[root@localhost named]# cp -p named.localhost kgc.com.zone
[root@localhost named]# vim kgc.com.zone 
www IN  A       192.168.200.90
[root@localhost named]# cp -p kgc.com.zone newkgc.com.zone 
[root@localhost named]# systemctl start named
[root@localhost named]# vim /etc/nginx/conf.d/default.conf 
server {
    listen       80;
    server_name  www.kgc.com;             //更换域名,域名修改
  
    #charset koi8-r;
    access_log  /var/log/nginx/host.access.log  main;         //开启日志
   
    location / {
        if ($host = 'www.kgc.com') {
          rewrite ^/(.*)$ http://www.newkgc.com/$1 permanent;
        }
[root@localhost named]# systemctl start nginx     //开启服务
[root@localhost named]# netstat -antp  | grep nginx
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      71112/nginx: master 
[root@localhost named]# netstat -antp  | grep named
tcp        0      0 192.168.200.90:53       0.0.0.0:*               LISTEN      70957/named         
tcp        0      0 127.0.0.1:53            0.0.0.0:*               LISTEN      70957/named         
tcp        0      0 127.0.0.1:953           0.0.0.0:*               LISTEN      70957/named         
tcp6       0      0 ::1:53                  :::*                    LISTEN      70957/named         
tcp6       0      0 ::1:953                 :::*                    LISTEN      70957/named
进去win10浏览器,输入www.kgc.com  域名转换到www.newkgc.com

2、基于客户端IP访问跳转

允许固定ip访问,禁止其他ip访问

[root@localhost named]# vim /etc/nginx/conf.d/default.conf 
          server_name  www.kgc.com;
          access_log  /var/log/nginx/host.access.log  main;
    #判断标志$rewrite
    set $rewrite true;
    #允许公司内部访问,更改标志位false
    if ($remote_addr = "192.168.200.11"){
      set $rewrite false;  
    } 
    #如果不是公司IP,加上后缀地址作为标志
    if ($rewrite = true) { 
      rewrite (.+) /error.html;
    } 
    location = /error.html {
      root /usr/share/nginx/html;
    } 
[root@localhost named]# cd /usr/share/nginx/html/
[root@localhost html]# ls
50x.html  index.html
[root@localhost html]# vim error.html    
<h1>this is error web !</h1>
[root@localhost html]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@localhost html]# systemctl restart nginx

在这里插入图片描述
在这里插入图片描述

3、基于旧、新域名调准并加目录

将域名bbs.kgc.com跳转到www.kgc.com/bbs

[root@localhost html]# vim /etc/nginx/conf.d/default.conf 
    server_name  bbs.kgc.com;
    access_log  /var/log/nginx/host.access.log  main;
    location /post {
       rewrite (.+) http://www.kgc.com/bbs$1 permanent;
    }
[root@localhost html]# vim /var/named/kgc.com.zone 
bbs IN  A       192.168.200.90
[root@localhost html]# systemctl restart named
[root@localhost html]# systemctl restart nginx

在这里插入图片描述在这里插入图片描述

4、基于参数匹配的跳转

如http://www.kgc.com/100-(100|200)-100.html跳转到http://www.kgc.com

[root@localhost html]#cd /var/named/
[root@localhost named]# vim kgc.com.zone 
www IN  A       192.168.200.90
[root@localhost named]# systemctl start named
[root@localhost named]# vim /etc/nginx/conf.d/default.conf 
    server_name  www.kgc.com;
    access_log  /var/log/nginx/host.access.log  main;
     if ($request_uri ~ ^/100-(100|200)-(\d+).html$){
       rewrite (.*) http://www.kgc.com permanent;
    }
[root@localhost named]# systemctl start nginx

5 、基于目录下所有php文件跳转

访问www.kgc.com/upload/1.php跳转到首页

[root@localhost named]# vim /etc/nginx/conf.d/default.conf
location ~* /upload/.*\.php$ {
       rewrite (.+) http://www.kgc.com permanent;
    }
[root@localhost named]# systemctl restart nginx    

在这里插入图片描述

在这里插入图片描述

6、基于最普通url请求跳转

访问一个最普通的页面跳转到首页浏览www.kgc.com/1/test.html跳转首页

[root@localhost named]# vim /etc/nginx/conf.d/default.conf
location ~* ^/1/test.html {
    rewrite (.+) http://www.kgc.com permanent;
}

在这里插入图片描述

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值