动静分离-nginxRewrite-set与if使用场景.

1.什么是动静分离/

将动态的请求和静态的请求区分访问,静态由Nginx处理,动态由php,tomcat处理

2.为什么要做动静分离?

因为tomcat程序本身是用来处理jsp代码的,但tomcat也能处理静态资源。tomcat本身处理静态效率不高,还会带来资源开销

3.如何实现动静分离

Nginx根据客户端请求的url来判断请求的是否是静态资源,如果请求的url包含jpg、png,则由Nginx处理。
如果请求的url是.php或者.jsp等等,这个时候这个请求是动态的,将转发给tomcat处理。

总结来说,Nginx是通过url来区分请求的类型,并转发给不同的服务端。

4.单机实现动静分离实战

安装程序

[[email protected] ~]# yum install java tomcat -y
[[email protected] ~]# mkdir /usr/share/tomcat/webapps/ROOT ----主要站点根目录

[[email protected] ~]# vi /usr/share/tomcat/webapps/ROOT/index.jsp

实验程序
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
    <html>
      <head>
        <title>Nginx+Tomcat</title>
      </head>
      <body>
          <%
            Random rand = new Random();
            out.println("<h2>动态资源</h2>");
            out.println(rand.nextInt(99)+100);
        %>
        <h2>静态图片</h2>
        <img src="nginx.png" />
      </body>
    </html>

[[email protected] ~]# wget -O /usr/share/tomcat/webapps/ROOT/nginx.png http://nginx.org/nginx.png ---下载静态图片
[[email protected] ~]# systemctl start tomcat

注:tomcat监听在8080端口

配置nginx

[[email protected] conf.d]# cat ds.oldxu.com.conf
server {
    listen 80;
    server_name ds.oldxu.com;

    location / {
        proxy_pass http://127.0.0.1:8080;
    }
    location ~* \.(png|gif|jpg|mp4)$ {
        root /images;
        expires 1d;
    }
}

劫持域名

5.集群实现,动静分离实战(有负载均衡,后端节点)

[email protected] conf.d]# cat  proxy_ds.oldxu.com.conf   --

upstream java {
    server 172.16.1.7:8080;
}
upstream static {
    server 172.16.1.8:80;
}
server {
    listen 80;
    server_name ds.oldxu.com;
    location / {
        proxy_pass http://java;
        include proxy_params;
    }

    location ~* \.(png|gif|jpeg)$ {
        proxy_pass http://static;
        expires 2d;
        include proxy_params;
    }
}

静态资源

server {
        listen 80;
        server_name ds.oldyang.com;
        location / {
                root /images;
                expires 1d;
}
}

二.Rewrite

1.什么是rewrite

Rewrite主要是实现url地址重写,以及url地址跳转

就是将用户请求的web服务器的url地址重新修改为其他url地址的过程

2.rewrite使用场景

1.地址跳转

2.协议跳转。

3.URL静态化

3.rewrite实现原理

3.Rewrite重写相关模块

1.set自定义变量

set语法

示例:set结合if实现变量的需求

mkdir -p /data/zh

mkdir -p /data/jp

mkdir -p /data/en

ehco "zh">/data/zh/index.html

ehco "jp">/data/jp/index.html

ehco "en">/data/en/index.html

server {
    listen 80;
    server_name url.oldyang.com.cn url.oldyang.com.jp;
        if ($http_host ~* cn){
        set $language zh;
        }
        if ($http_host ~* jp){
        set $language jp;

}

        rewrite ^/$ http://url.oldyang.com/$language/;
}
server {
        listen 80;
        server_name url.oldyang.com;
        location / {
        root /data;
}
}

2.if指令场景示例

需求:根据用户浏览器使用的语言,自动判断并跳转到不同的语言界面

中国            url.oldxu.com    ---> url.oldxu.com   --->中文
english            url.oldxu.com    ---> url.oldxu.com   --->english

server {
    listen 80;
    server_name url.oldxu.com;

    location / {
        if ( $http_accept_language ~* "en" ) {
            set $language en;
        }
        if ( $http_accept_language ~* "zh|zh-CN" ) {
            set $language zh;
        }

        root /data/$language;
    }
}

需求:Nginx过滤请求中包含a1=3526的http请求到10.0.3.05的8080端口处理

server {
listen 80;
server_name url.oldxu.com;

location / {
default_type text/html;
if ($request_uri ~* "a1=3526") {
return 200 "https://www.jd.com";
}
if ($request_uri ~* "git"){
return 403;
}
if ($request_uri ~* "^/test") {
return 302 "https://www.jd.com";
}
if ( $http_accept_language ~* "en" ) {
set $language en;
}
if ( $http_accept_language ~* "zh|zh-CN" ) {
set $language zh;
}
root /data/$language;
}

return 返回数据

1.return 指令语法

停止一切处理,返回结果给客户端,如果返回的状态码是 444,则断开 TCP 连接,不发送任何东西。

可以使用的状态码有:204,400,402-406,408,410, 411, 413, 416 与 500-504。

如果不带状态码直接返回 URL 则被视为 302

2.return的三种使用场景

erver {
    listen 80;
    server_name url.oldxu.com;

    location / {
        default_type text/html;
        if ($request_uri ~* "a1=3526") {
            return 200 "https://www.jd.com";
        }
        if ($request_uri ~* "git"){
            return 403;
        }
        if ($request_uri ~* "^/test") {
            return 302 "https://www.jd.com";
        }
        if ( $http_accept_language ~* "en" ) {
            set $language en;
        }
        if ( $http_accept_language ~* "zh|zh-CN" ) {
            set $language zh;
        }
        root /data/$language;
    }

break 表示要停止后续的操作

server {
    listen 80;
    server_name url.oldxu.com;
    root /code;

    location / {
        rewrite /1.html /2.html
    break;
        rewrite /2.html /3.html;
    }

    location /2.html {
        rewrite /2.html /a.html;
    }

    location /3.html {
        rewrite /3.html /b.html;
    }
} 

[[email protected]]# echo "1.html" >/code/1.html
[[email protected]]# echo "2.html" >/code/2.html
[[email protected]]# echo "3.html" >/code/3.html
[[email protected]]# echo "a.html" >/code/a.html
[[email protected]]# echo "b.html" >/code/b.html

rewrite

在 rewrite 中有 4 个 flag 参数:

参数 说明
last 停止所有 rewrite 相关指令,然后使用新的 URI 进行 location 匹配。
break 停止所有 rewrite 相关指令, 和 last 不同的是,last 接着继续使用新的 URI 匹配 location。而 break 则是直接使用当前的 URI 进行请求处理,能避免重复 rewrite,last 一般在 server,break 一般在 location。
redirect URI 中不包含协议如 https://,但依然希望它返回 30x,让浏览器二次请求然后获取到结果就需要 redirect。
permanent 和 redirect 类似,但是直接返回 301 永久重定向。

根据不同的语言

server {
    listen 80;
    server_name url.oldxu.com;
    root /data;

    set $language /default;
    if ( $http_accept_language ~* zh ) {
        set $language /zh;
    }
    if ( $http_accept_language ~* en ) {
        set $language /en;
    }
    if ( $http_accept_language ~* ja ) {
        set $language /jp;
    }

    rewrite ^/$ $language;

    location / {
        index index.html;
    }
}

跳转永久维护页面

erver {
    listen 80;
    server_name url.oldxu.com;
    root /data;

    rewrite ^(.*)$ /wh.png break;

    set $language /default;
    if ( $http_accept_language ~* zh ) {
        set $language /zh;
    }
    if ( $http_accept_language ~* en ) {
        set $language /en;
    }
    if ( $http_accept_language ~* ja ) {
        set $language /jp;
    }

    rewrite ^/$ $language;

    location / {
        index index.html;
    }
}

临时维护

#error_page 403 404 500 502 /wh.png;
    #error_page 403 404 500 502 http://$http_host;

    error_page 403 404 500 502 @temperror;
    location @temperror {
            rewrite ^(.*)$ http://$http_host;
    }

需求: 用户通过手机设备访问url.oldxu.com,跳转至url.oldxu.com/m

server {
listen 80;
server_name url.oldxu.com;
root /data;

if ($http_user_agent ~* "android|iphone|ipad") {
rewrite ^/$ /m;
}
}

需求: 用户通过手机设备访问url.oldxu.com,跳转至m.oldxu.com

   listen 80;
    server_name url.oldxu.com;
    root /data;

    if ($http_user_agent ~* "android|iphone|ipad") {
        rewrite ^/$  http://m.oldxu.com;
    }
}
server {
    listen 80;
    server_name m.oldxu.com;
    root /data/m;

    location / {
        index index.html;
    }
}

#需求: 用户访问oldxu.com/test,跳转至https://xuliangwei.com

两种方式匹配test

1.location

location /test {
                #rewrite ^(.*)$ https://www.xuliangwei.com/;
                return 302 https://www.xuliangwei.com/;
        }

2.if

server {
        listen 80;
        server_name url.oldxu.com;
        root /data;

        if ($request_uri ~* "^/test") {
            #rewrite ^(.*)$ https://www.xuliangwei.com/;
            return 302 https://www.xuliangwei.com/;
        }
        location / {
            index index.html;
        }
    }

3.rewrite场景示例: 开发
需求: 用户访问course-11-22-33.html实际上真实访问是/course/11/22/33/course_33.html

[email protected] conf.d]# cat url.oldxu.com.conf
server {
    listen 80;
    server_name url.oldxu.com;
    root /data;
    location /  {
        index index.html;
                #用户访问的url        #文件真实位置
        rewrite ^/(.*)-(.*)-(.*)-(.*).html /$1/$2/$3/$4/$1_$4.html;
    }
}

原文地址:https://www.cnblogs.com/hh-y/p/11580560.html

时间: 2024-10-22 10:42:50

动静分离-nginxRewrite-set与if使用场景.的相关文章

关于大型网站技术演进的思考(十一)--网站静态化处理—动静分离策略(3)

前文里我讲到了网站静态化的关键点是动静分离,动静分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化处理的核心思路.由此可见,网站静态化处理的核心就是动静分离和缓存两大方面,上篇我简单讲述了动静整合的基础知识,本篇将会讲述两大核心之一的动静分离策略,只有把动静分离策略做好了,缓存才能发挥出它应有的效果. 下面我们要讨论下动静分离的策略了,一个页面什么内容是动态的,什么内容是静态的,这个我们

varnish的缓存加速,以及动静分离,负载均衡

一个简单的拓扑如上,varnish1 上还同时开了nginx,用来做静态的http,app1和app2 是nginx+fastcgi,这个拓扑主要做的是Discuz!论坛的动静分离,以及app的负载均衡,varnish起到个反向代理和缓存加速的功能. varnish1:192.168.1.151,172.16.0.51 app1:172.16.0.52 app3:172.16.0.54 varnish 简介 varnish的缓存方式: 1.malloc,通过malloc获取内存,简单,速度. 2

LNMMP架构实现Web动静分离

前言 前面的文章中说过LAMP架构包括:Linux操作系统,Apache网站服务器,MySQL数据库,Perl.PHP或者Python编程语言,而今天要说的LNMMP 和LAMP类似,只是作为Web服务器的不再是Apache而是高性能的Nginx,同时引进Memcached加速缓存效率,用于加快访问速度. Memcached是一款开源.高性能.分布式内存对象缓存系统,可应用各种需要缓存的场景,其主要目的是通过降低对数据库的访问来加速Web应用程序.它是一个基于内存的"键值对"存储,用于

HAproxy负载均衡动静分离实现及配置详解

 HAproxy负载均衡动静分离实现及配置详解 HAproxy的介绍 HAProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案.HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理.HAProxy运行在时下的硬件上,完全可以支持数以万计的并发连接.并且它的运行模式使得它可以很简单安全的整合进您当前的架构中, 同时可以保护你的web服务器不被暴露到网络上. HAProxy实现了一种事件驱动.单一进程

Varnish的负载均衡、动静分离

一.Varish的简介 Varnish是一款高性能的开源HTTP加速器,挪威最大的在线报纸 Verdens Gang 使用3台Varnish代替了原来的12台Squid,性能比以前更好. 在当前主流的Web架构中,Cache担任着越来越重要的作用.常见的基于浏览器的C/S架构,Web Cache更是节约服务器资源的关键.而最近几年由FreeBSD创始人之一Kamp开发的varnish更是一个不可多得的Web Cache Server.严格意义上说,Varnish是一个高性能的反向代理软件,只不过

HAPorxy详解及动静分离实例

一.HAProxy简介 HAProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案.   HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理.HAProxy运行在时下的硬件上,完全可以支持数以万计的并发连接.    并且它的运行模式使得它可以很简单安全的整合进您当前的架构中, 同时可以保护你的web服务器不被暴露到网络上. HAProxy实现了一种事件驱动.单一进程模型,此模型支持非常大的并发连接

KeepAlived实现HAProxy双主并实现资源的动静分离

KeepAlived实现HAProxy双主并实现资源的动静分离 大纲 前言 HAProxy介绍 实验拓扑 实验环境 实验步骤 配置后端httpd服务器 配置HAProxy实现backend负载均衡 测试动静分离效果 配置KeepAlived 测试KeepAlived 配置DNS DNS测试 最终测试 总结 前言 我们这次使用HAProxy作为负载均衡调度器来实现后端httpd服务的负载均衡和动静分离,并使用KeepAlived让HAproxy实现双主高可用, 再使用DNS轮询将用户对www.an

【转】关于大型网站技术演进的思考(十一)--网站静态化处理—动静分离策略(3)

前文里我讲到了网站静态化的关键点是动静分离,动静分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化处理的核心思路.由此可见,网站静态化处理的核心就是动静分离和缓存两大方面,上篇我简单讲述了动静整合的基础知识,本篇将会讲述两大核心之一的动静分离策略,只有把动静分离策略做好了,缓存才能发挥出它应有的效果. 下面我们要讨论下动静分离的策略了,一个页面什么内容是动态的,什么内容是静态的,这个我们

5.3 Nginx 动静分离

Server 脚本片段 server { listen 80; server_name ccserver1; #charset koi8-r; access_log logs/host.access.log main; index index.html index.htm index.jsp; root /usr/tomcat-8.0.0-RC5-1/webapps/ROOT/; location ~* .*\.(jpg|jpeg|gif|png|swf|ico)$ { if (-f $requ