nginx和tomcat实现动静分离

动态和静态

静态请求:不需要访问数据库
动态请求:需要访问数据库,登录

静态页:打开一个网页,不需要访问数据库
动态页:打开一个网页,需要访问数据库

企业中无论是静态资源还是动态资源,都需要做共享存储

web单台服务器实现动静分离

location / {
    listen 80;
    server_name cs.dj.com
    root /code/wordpress;
    index index.php;
}

location ~* \.(png|jpg|mp4|)${
    root /code/wordpress/images;
    gzip on;
}

location ~* \.php$ {
    fastcgi_pass 127.0.0.1:9000;
}

#location支持扩展正则

多台服务器实现动静分离

环境准备

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

web01配置静态资源

[root@web01 ~]# vim /etc/nginx/conf.d/jt.conf
server {
        listen 80;
        server_name cs.jd.com;
        root /code;
        index index.html;

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

#配置一个主页
[root@web01 conf.d]# echo "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
[root@web01 conf.d]# nginx -s reload

#浏览器访问

web02配置动态资源

Tomcat处理Java代码,是Java的容器,可以直接解析Java代码(.jsp结尾),不需要代理
resin处理Java代码,是Java的容器,可以直接解析Java代码,不需要代理

Tomcat的访问与nginx无关,可以做静态资源和动态资源的网页
apache官网

Tomcat和Nginx的区别
从应用方面 tomcat一般是做'动态解析'才会用得到,支持jsp(Java Server Pages包括html和java,可以写java代码也可以写html和js代码,就像.asp页面一样可以写c#和html还有js)的解析,需要配置JDK支持 
nginx,则一般是做'静态'(html和js),本身不具备动态解析功能,需要配置其他插件或通过其他软件协同才具备动态功能,比如php,tomcat,或者proxypass到win2008的iis服务器做ASP的动态链接等,
但nginx在静态上的功能非常强大,也可做访问控制,而且可以做成各种协议负载服务器,包括流媒体的也可以做,具体得去官方网站去看; 在性能方面 如果再不做系统调优的情况下 'tomcat一般支持并发(并发是一秒钟的访问量)并不高100个差不多了' 'nginx在静态方面支持并发轻松达几万'
如果这是个面试的人给你出的这道题目上你回答,你可以简单的告诉他,两者应用领域不一样,tomcat是做java语言的动态解析,而nginx则是一款功能强大的负载软件,配合各种插件可以实现

1.#查看jdk是否安装
[root@web01 ~]# yum install -y java
[root@web01 ~]# java -version		# jdk可以理解为Java的依赖,jdk属于Java
openjdk version "1.8.0_252"
OpenJDK Runtime Environment (build 1.8.0_252-b09)
OpenJDK 64-Bit Server VM (build 25.252-b09, mixed mode)

2.
[root@web02 ~]# yum install -y tomcat

3.#创建ROOT,因为Tomcat默认站点目录是ROOT/
[root@web02 ~]# mkdir /usr/share/tomcat/webapps/ROOT

4.
[root@web02 ~]# vim /usr/share/tomcat/webapps/ROOT/1.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<HTML>
    <HEAD>
        <TITLE>阳阳</TITLE>
    </HEAD>
    <BODY>
        <%
            Random rand = new Random();
            out.println("<h1>阳阳随机数:<h1>");
            out.println(rand.nextInt(99)+100);
        %>
    </BODY>
</HTML>

[root@web02 ~]# systemctl start tomcat

5.#做一个默认页面
[root@web02 ~]# vim /usr/share/tomcat/webapps/ROOT/index.html
web02

6.# 打开浏览器访问
http://10.0.0.8:8080/1.jsp

#访问这个随机数网页,并没有访问数据库

tJeVnx.md.png
tJeAj1.md.png

负载均衡上整合静态资源和动态资源

[root@lb01 conf.d]# vim /etc/nginx/conf.d/jd.conf 
upstream static {
        server 172.16.1.7:80;
}

upstream java {
        server 172.16.1.8:8080;
}

server {
        listen 80;
        server_name cs.jd.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
[root@lb01 conf.d]# nginx -s reload

2.配置本地hosts,通过负载访问动态与静态资源(注意Tomcat的端口)

tJeK4e.md.png

负载均衡上整合动静分离模板

[root@lb01 ~]# vim /etc/nginx/conf.d/djfl.conf
upstream static {
        server 172.16.1.7:80;
}

upstream java {
        server 172.16.1.8:8080;
}

server {
        listen 80;
        server_name cs.jd.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://cs.jd.com/1.jsp",	
        success: function(data){
                $("#get_data").html(data)
        },
        error: function() {
                alert("哎呦喂,失败了,回去检查你服务去~");
        }
        });
});
</script>
        <body>
                <h1>曾老湿带你测试动静分离</h1>
                <img src="http://cs.jd.com/1.gif">	
                <div id="get_data"></div>
        </body>
</html>

tomcat

<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://cs.jd.com/1.jsp",	#类似于index.html
        success: function(data){
                $("#get_data").html(data)
        },
        error: function() {
                alert("哎呦喂,失败了,回去检查你服务去~");
        }
        });
});
</script>
        <body>
                <h1>曾老湿带你测试动静分离</h1>
                <img src="http://cs.jd.com/1.gif">	##
                <div id="get_data"></div>
        </body>
</html>

Nginx资源分离场景实践

系统版本 主机角色 外网IP 内网IP 提供端口
CentOS7.5 负载均衡 10.0.0.5 172.16.1.5 80
CentOS7.5 提供Android页面 10.0.0.7 172.16.1.7 9090
CentOS7.5 提供Iphone页面 10.0.0.7 172.16.1.7 9091
CentOS7.5 提供pc页面 10.0.0.7 172.16.1.7 9092
posted @ 2020-06-01 17:16  看萝卜在飘  阅读(409)  评论(0编辑  收藏  举报