欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

实现动静分离

程序员文章站 2022-09-27 16:34:49
[toc] nginx 实现动静分离 Nginx动静分离基本概述 动静分离,通过中间件将动静分离和静态请求进行分离; 通过中间件将动态请求和静态请求分离,可以建上不必要的请求消耗,同事能减少请求的延时。 通过中间件将动态请求和静态请求分离,逻辑图如下: 动静分离只有好处:动静分离后,即使动态服务不可 ......

nginx 实现动静分离

nginx动静分离基本概述

动静分离,通过中间件将动静分离和静态请求进行分离;
通过中间件将动态请求和静态请求分离,可以建上不必要的请求消耗,同事能减少请求的延时。
通过中间件将动态请求和静态请求分离,逻辑图如下:

实现动静分离

动静分离只有好处:动静分离后,即使动态服务不可用,但静态资源不会受到影响。

nginx动静分离场景实践

location / {
    root /code/wordpress;
    index.php;
}
location ~* \.(png|jpg|mp4|)${
    root /code/wordpress/images;
    gzip on;
    .....
}
location ~ \.php$ {
    fastcgi_pass 127.0.0.1:9000;
    .....
}

多台服务器实现动静分离

实现动静分离

1.环境准备

系统 作用 服务 地址
centos7.5 负载均衡 nginx proxy 10.0.0.5
centos7.5 静态资源 nginx static 10.0.0.7
centos7.5 动态资源 tomcat server 10.0.0.8

2.web配置静态资源

[root@web01 ~]# cd /etc/nginx/conf.d/
[root@web01 conf.d]# cat ds_oldboy.conf 
server {
        listen 80;
        server_name pic.drz.com;
        root /code;
        index index.html;

        location ~* .*\.(jpg|png|gif)$ {
                root /code/images;
        }
}

#配置一个主页
[root@web01 conf.d]# echo "zls_test_web01" > /code/index.html

#创建图片目录
[root@web01 conf.d]# mkdir /code/images/

#上传一个静态文件
[root@web01 conf.d]# cd /code/images/
[root@web01 images]# rz cjk.gif

[root@web01 conf.d]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@web01 conf.d]# nginx -s reload

3.验证

打开浏览器访问:

实现动静分离

打开浏览器访问:
实现动静分离

4.web02配置动态资源

[root@web02 ~]# yum install -y tomcat
[root@web02 ~]# mkdir /usr/share/tomcat/webapps/root
[root@web02 ~]# cat /usr/share/tomcat/webapps/root/java_test.jsp
<%@ page language="java" import="java.util.*" pageencoding="utf-8"%>
<html>
    <head>
        <title>曾老湿jsp page</title>
    </head>
    <body>
        <%
            random rand = new random();
            out.println("<h1>曾老湿随机数:<h1>");
            out.println(rand.nextint(99)+100);
        %>
    </body>
</html>

[root@web02 webapps]# systemctl start tomcat

打开浏览器,访问:

实现动静分离

5.负载均衡上调度

[root@lb01 conf.d]# cat proxy_ds.conf 
upstream static {
        server 172.16.1.7:80;
}

upstream java {
        server 172.16.1.8:8080;
}

server {
        listen 80;
        server_name pic.drz.com;
       
        location ~* \.(jpg|png|gif)$ {
                proxy_pass http://static;
                proxy_set_header host $http_host;
        }

        location ~ \.jsp {
                proxy_pass http://java;
                proxy_set_header host $http_host;
        }
}

[root@lb01 conf.d]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@lb01 conf.d]# nginx -s reload

2.5 配置本地hosts,通过负载访问动态与静态资源
动态资源 ↓

实现动静分离

静态资源 ↓

实现动静分离

网站主页 ↓

实现动静分离

6.负载均衡上整合动态和静态的html文件

#编辑配置文件
[root@lb01 ~]# cat /etc/nginx/conf.d/proxy_ds.conf
upstream static {
        server 172.16.1.7:80;
}

upstream java {
        server 172.16.1.8:8080;
}

server {
        listen 80;
        server_name pic.drz.com;
        
        location / {
            root /code;
            index index.html;
        }
        
        location ~* \.(jpg|png|gif)$ {
                proxy_pass http://static;
                proxy_set_header host $http_host;
        }

        location ~ \.jsp {
                proxy_pass http://java;
                proxy_set_header host $http_host;
        }
}

[root@lb01 ~]# mkdir -p /code

#编辑整合后的index.html
[root@lb01 ~]# cat /code/index.html
<html lang="en">
<head>
        <meta charset="utf-8" />
        <title>曾老湿测试ajax和跨域访问</title>
        <script src="http://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
</head>
<script type="text/javascript">
$(document).ready(function(){
        $.ajax({
        type: "get",
        url: "http://pic.drz.com/java_test.jsp",
        success: function(data){
                $("#get_data").html(data)
        },
        error: function() {
                alert("哎呦喂,失败了,回去检查你服务去~");
        }
        });
});
</script>
        <body>
                <h1>曾老湿带你测试动静分离</h1>
                <img src="http://pic.drz.com/cjk.gif"># 上传的图片名
                <div id="get_data"></div>
        </body>
</html>

7.浏览器访问测试动静分离是否成功

实现动静分离

可以尝试关掉静态或者动态的服务,测试是否互不影响

nginx资源分离场景实践

nginx通过负载均衡实现手机与pc调度至不通的后端节点应用案例

根据iphone、安卓,pc跳转不通的页面环境规划

系统版本 主机角色 外网ip 内网ip 提供端口
centos7.5 负载均衡 10.0.0.5 172.16.1.5 80
centos7.5 提供android页面 172.16.1.7 9090
centos7.5 提供iphone页面 172.16.1.7 9091
centos7.5 提供pc页面 172.16.1.7 9092

1.配置后端web节点的nginx配置

[root@web01 conf.d]# vim sj.conf
server {
        listen 9090;
        location / {
                root /code/android;
                index index.html;
        }
}

server {
        listen 9091;
        location / {
                root /code/iphone;
                index index.html;
        }
}

server {
        listen 9092;
        location / {
                root /code/pc;
                index index.html;
        }
}

2.为后端web节点配置对应的网站目录及代码

[root@web01 conf.d]# mkdir /code/{android,iphone,pc}
[root@web01 conf.d]# echo "我是安卓" > /code/android/index.html
[root@web01 conf.d]# echo "我是iphone" > /code/iphone/index.html
[root@web01 conf.d]# echo "我是computer" > /code/pc/index.html

3.配置负载均衡服务,根据不同的浏览器调度到不同的资源地

[root@lb01 conf.d]# vim /etc/nginx/conf.d/proxy_sj.conf
upstream android {
        server 172.16.1.7:9090;
}

upstream iphone {
        server 172.16.1.7:9091;
}

upstream pc {
        server 172.16.1.7:9092;
}

server {
        listen 80;
        server_name sj.drz.com;
        charset 'utf-8';

        location / {

                #如果客户端来源是android则跳转到android的资源;
                if ($http_user_agent ~* "android") {
                        proxy_pass http://android;
                }

                #如果客户端来源是iphone则跳转到iphone的资源;
                if ($http_user_agent ~* "iphone") {
                        proxy_pass http://iphone;
                }

                #如果客户端是ie浏览器则返回403错误;
                if ($http_user_agent ~* "msie") {
                        return 403;
                }

                #默认跳转pc资源;
                proxy_pass http://pc;
        }
}

4.使用浏览器访问,查看结果

实际上的配置

server {
        listen 80;
        server_name   www.drz.com;
        if ($http_user_agent ~* "android|iphone") {   #修改负载,wel上也改
                rewrite ^/$ https://sj.drz.com redirect;
        }       
}