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动态页面跳转

相关推荐
web小白成长日记22 分钟前
企业级 Vue3 + Element Plus 主题定制架构:从“能用”到“好用”的进阶之路
前端·架构
APIshop1 小时前
Python 爬虫获取 item_get_web —— 淘宝商品 SKU、详情图、券后价全流程解析
前端·爬虫·python
风送雨1 小时前
FastMCP 2.0 服务端开发教学文档(下)
服务器·前端·网络·人工智能·python·ai
XTTX1101 小时前
Vue3+Cesium教程(36)--动态设置降雨效果
前端·javascript·vue.js
LYFlied2 小时前
WebGPU与浏览器边缘智能:开启去中心化AI新纪元
前端·人工智能·大模型·去中心化·区块链
Setsuna_F_Seiei2 小时前
2025 年度总结:人生重要阶段的一年
前端·程序员·年终总结
model20052 小时前
alibaba linux3 系统盘网站迁移数据盘
java·服务器·前端
han_3 小时前
从一道前端面试题,谈 JS 对象存储特点和运算符执行顺序
前端·javascript·面试
aPurpleBerry3 小时前
React 01 目录结构、tsx 语法
前端·react.js
jayaccc3 小时前
微前端架构实战全解析
前端·架构