Nginx+Tomcat负载均衡、动静分离

七层反向代理+动静分离

Matlab 复制代码
实验配置:
nginx:20.0.0.61 代理又是静态
tomcat1:20.0.0.71
tomcat2:20.0.0.72
Matlab 复制代码
[root@nginx1 conf]# vim nginx.conf

http {
    ...
    upstream tomcat {
        server 20.0.0.71:8080 weight=1;
        server 20.0.0.72:8080 weight=1;
    }
    server {
        ...
        location / {
            root   html;
            index  index.html index.htm;
        }

        location ~* \.jsp$ {
            proxy_pass http://tomcat;
            proxy_set_header HOST $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }

[root@nginx1 conf]# nginx -t
[root@nginx1 conf]# systemctl restart nginx
复制代码
[root@nginx1 conf]# cd ..
[root@nginx1 nginx]# cd html/
[root@nginx1 html]# vim index.html

<html>
<body>
<h1> this is Nginx static test1 !</h2>
<img src="naruto.PNG"/>
</body>
</html>

--传入naruto.PNG--

浏览器访问20.0.0.61

Matlab 复制代码
[root@tomcat1 ~]# cd /usr/local/tomcat/
[root@tomcat1 tomcat]# cd webapps/
[root@tomcat1 webapps]# mkdir test
[root@tomcat1 webapps]# cd test/
[root@tomcat1 test]# vim index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test1 page</title>
</head>
<body>
<% out.println("动态页面 1,http://www.test1.com");%>
</body>
</html>

[root@tomcat2 ~]# cd /usr/local/tomcat/
[root@tomcat2 tomcat]# cd webapps/
[root@tomcat2 webapps]# mkdir test
[root@tomcat2 webapps]# cd test/
[root@tomcat2 test]# vim index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test2 page</title>
</head>
<body>
<% out.println("动态页面 2,http://www.test2.com");%>
</body>
</html>
Matlab 复制代码
71、72相同操作:
[root@tomcat1 conf]# vim server.xml
--删除--
<Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
--插入--
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">        <Context docBase="/usr/local/tomcat/webapps/test" path="" reloadable="true" />
Matlab 复制代码
71、72相同操作:
[root@tomcat1 conf]# cd ..
[root@tomcat1 tomcat]# cd bin/
[root@tomcat1 bin]# ./startup.sh 

浏览器直接访问71、72动态页面

浏览器访问代理服务器跳转至动态页面

四层+七层+动静分离

Matlab 复制代码
实验配置:
nginx代理:20.0.0.61
静态页面和动态请求转发服务器:
nginx2:20.0.0.62
nginx3:20.0.0.63
tomcat1:20.0.0.71
tomcat2:20.0.0.72
Matlab 复制代码
[root@nginx1 conf]# vim nginx.conf

stream {
        upstream static {
            server 20.0.0.62:80 weight=1;
            server 20.0.0.63:80 weight=1;
        }
    server {
        listen 80;
        proxy_pass static;
    }
}

[root@nginx1 conf]# nginx -t
[root@nginx1 conf]# systemctl restart nginx
Matlab 复制代码
62、63相同操作:
[root@nginx2 conf]# vim nginx.conf

upstream tomcat {
        server 20.0.0.71:8080 weight=1;
        server 20.0.0.72:8080 weight=1;
}

    server {
        listen       80;
        server_name  localhost;

        location / {
            root   html;
            index  index.html index.htm;
        }
         location ~* \.jsp$ {
            proxy_pass http://tomcat;
            proxy_set_header HOST $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
Matlab 复制代码
[root@nginx2 html]# vim index.html 

<html>
<body>
<h1> this is Nginx static test1 !</h2>
<img src="naruto.PNG"/>
</body>
</html>

--传入naruto.PNG--

[root@nginx3 html]# vim index.html 

<html>
<body>
<h1> this is Nginx static test2 !</h2>
<img src="sasuke.PNG"/>
</body>
</html>

--传入sasuke.PNG--

浏览器访问20.0.0.61请求静态页面

浏览器访问20.0.0.61动态页面跳转

相关推荐
浩浩测试一下14 分钟前
渗透信息收集- Web应用漏洞与指纹信息收集以及情报收集
android·前端·安全·web安全·网络安全·安全架构
西陵39 分钟前
Nx带来极致的前端开发体验——借助CDD&TDD开发提效
前端·javascript·架构
小磊哥er1 小时前
【前端工程化】前端工作中的业务规范有哪些
前端
ᥬ 小月亮1 小时前
webpack基础
前端·webpack
YongGit1 小时前
探索 AI + MCP 渲染前端 UI
前端·后端·node.js
慧一居士2 小时前
<script setup>中的setup作用以及和不带的区别对比
前端
RainbowSea2 小时前
NVM 切换 Node 版本工具的超详细安装说明
java·前端
读书点滴2 小时前
笨方法学python -练习14
java·前端·python
Mintopia3 小时前
四叉树:二维空间的 “智能分区管理员”
前端·javascript·计算机图形学
Mintopia3 小时前
Three.js 深度冲突:当像素在 Z 轴上玩起 "挤地铁" 游戏
前端·javascript·three.js