Nginx(四层+七层代理)+Tomcat实现负载均衡、动静分离

一、Tomcat多实例部署

具体步骤请看我之前的博客

写文章-CSDN创作中心https://mp.csdn.net/mp_blog/creation/editor/134956765?spm=1001.2014.3001.9457

1.1 访问测试多实例的部署

1.2 分别在三个tomcat服务上部署jsp的动态页面

复制代码
mkdir /usr/local/tomcat/webapps/test
vim /usr/local/tomcat/webapps/test/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test1 page</title>   #指定为 test1 页面
</head>
<body>
<% out.println("动态页面 1,http://www.test1.com");%>
</body>
</html>

测试一下:

二、nginx的七层代理,实现动静分离(192.168.136.130)

步骤一、安装nginx,并部署nginx基于协议的反向代理(七层代理)

bash 复制代码
##先定义一个后端服务器池的名称为tomcat server 这名称自定义的,会与后面调用相关联对用三个tomcat服务
upstream tomcat_server {
                server 192.168.136.100:8080 weight=1;    
                server 192.168.136.110:8080 weight=1;
                server 192.168.136.110:8081 weight=1;
        }
    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;
#location匹配到以jsp结尾的请求 转发给后端服务器池proxy_pass http:// 表示基于http协议进行转发,这是七层反向代理
    location ~ .*\.jsp$ {
        proxy_pass http://tomcat_server;
        proxy_set_header HOST $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        
        }
#access_log  logs/host.access.log  main;
#location匹配静态请求那么由nginx自身处理
        location / {
            root   html;
            index  index.html index.htm;
        }

步骤二、实现动静分离

bash 复制代码
        location ~ .*\.jsp$ {
        proxy_pass http://tomcat_server;
        proxy_set_header HOST $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 
        }
        #access_log  logs/host.access.log  main;
 
        location /static {
            root   html;
            index  index.html index.htm;
        }

步骤三:准备好静态页面,用于测试

130主机:

140主机:

步骤四:验证结果

192.168.136.130的动静分离验证

静态:

动态:

动态页面请求验证

192.168.136.140的动静分离验证

静态:

动态:

三、nginx的四层代理,实现负载均衡

步骤一:yum安装nginx(120主机上),部署四层反向代理

bash 复制代码
stream {
 14 
 15     upstream nginx_server {
 16                 server 192.168.136.130:80;
 17                 server 192.168.136.140:80;
 18     }
 19     server {
 20         listen 9527;
 21         proxy_pass nginx_server;
 22     }
 23 }   

步骤二:验证结果

相关推荐
qq7621182230 分钟前
Linux c 在内存中创建zip,最后写入测试
linux·运维·服务器
故事很腻i1 小时前
安装elk
运维·elk·jenkins
华纳云IDC服务商1 小时前
网站服务器频繁掉线的主要原因是什么
运维·服务器
小黄人软件1 小时前
【部署python网站】宝塔面板 小目标2:实时搜索网上资源文件网站放在服务器上 用AI做一个作品,不断迭代。
运维·服务器
未来之窗软件服务1 小时前
服务器运维(四)服务器漏洞扫描工具与审查——东方仙化神期
运维·服务器·仙盟创梦ide·东方仙盟·东方仙盟运维
云飞云共享云桌面1 小时前
SolidWorks服务器多人使用方案
大数据·运维·服务器·前端·网络·电脑·制造
你疯了抱抱我1 小时前
【H3C NX30Pro】光猫桥接并使用OpenWRT配置NAS端口映射;配置IPv6、IPv4公网直连内网服务器;
运维·服务器·网络·智能路由器·路由器
liyugang20151 小时前
MySQL数据库性能优化的七个关键策略与实践
运维
IT成长日记7 小时前
【Nginx开荒攻略】Nginx虚拟主机配置:从域名、端口到IP的完整指南
linux·运维·服务器·nginx·虚拟主机
taxunjishu7 小时前
DeviceNet 转 Modbus TCP 协议转换在 S7-1200 PLC化工反应釜中的应用
运维·人工智能·物联网·自动化·区块链