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 }   

步骤二:验证结果

相关推荐
Ztiddler5 小时前
【Linux Shell命令-不定期更新】
linux·运维·服务器·ssh
小小不董5 小时前
Oracle OCP认证考试考点详解082系列16
linux·运维·服务器·数据库·oracle·dba
IPdodo全球网络5 小时前
如何利用静态住宅IP优化Facebook商城的网络稳定性与运营效率
运维·服务器
运维&陈同学5 小时前
【模块一】kubernetes容器编排进阶实战之k8s基础概念
运维·docker·云原生·容器·kubernetes·云计算
40kuai6 小时前
Ingress nginx 公开TCP服务
nginx·ingress
m0_519523106 小时前
Linux——简单认识vim、gcc以及make/Makefile
linux·运维·vim
mit6.8246 小时前
[Docker#4] 镜像仓库 | 部分常用命令
linux·运维·docker·容器·架构
zyp2468106 小时前
Linux之DNS服务器
linux·运维·服务器
wdxylb7 小时前
将C++搭建的简单HTTP服务器升级为 HTTPS 服务器
运维·服务器·https
Denzel张7 小时前
ubuntu_dpkg_dep_list
linux·运维·ubuntu