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 }   

步骤二:验证结果

相关推荐
AOwhisky8 小时前
Redis 学习笔记(第三期):持久化与主从复制
运维·数据库·redis·笔记·学习·云计算
c238568 小时前
Linux C++ 进度条进阶美化与工程化封装
linux·运维·服务器
李小白668 小时前
第四天-WEB服务器基本原理,IIS服务
运维·服务器·前端
2401_834636998 小时前
Nginx 从入门到实战:静态 / 动态站点、PHP 部署与反向代理全解析
运维·nginx·php
aosky9 小时前
一台电脑配置多个 SSH Key 对应不同的 GitHub 账号
运维·ssh·github
云登指纹浏览器10 小时前
WebDriver反检测技术详解:如何让自动化脚本看起来像真实浏览器
运维·自动化·跨境电商
xmtxz10 小时前
计算机网络基础课程学习心得:从理论抽象到硬核实战的进阶之路
运维·学习
RisunJan11 小时前
Linux命令-pgrep (通过进程名查找进程 ID)
linux·运维
回忆2012初秋11 小时前
【Nginx】优雅地走进高性能 Web 服务器世界(1)
服务器·前端·nginx
信创工程师-小杨11 小时前
Linux内网环境如何解决依赖的问题
linux·运维·服务器