Nginx+Tomcat部署负载均衡、动静分离集群(相关理论+模拟实验)

一、概述

Nginx服务器作为前端,Tomcat服务器作为后端,web页面请求由Nginx服务来进行转发。
但不是把所有的web请求都转到Tomcat服务器,而是由Nginx服务器自己处理静态页面请求;动态页面请求转发给后端的Tomcat服务器来处理。

众所周知,Tomcat是属于轻量级的应用服务器,可接受访问量可能会不足,所以我们需要多台Tomcat服务器,然后通过Nginx配置权重来进行挑选Tomcat服务器去进行处理,以实现负载均衡的一种策略。

二、原理

  • Nginx服务器首页使用精准匹配
  • 静态页面Nginx服务器使用正则匹配自己处理
  • 动态页面Nginx服务器使用正则匹配jsp结尾的请求,使用proxy_pass转发给Tomcat服务器

2.1 Nginx处理静态页面的优势

  • Nginx处理静态页面的效率远高于Tomcat的处理能力
  • 若Tomcat的请求量为1000次,则Nginx的请求量为6000次
  • Tomcat每秒的吞吐量为0.6M,Nginx的每秒吞吐量为3 .6M
  • Nginx处理静态资源的能力是Tomcat处理的6倍

2.2 Nginx动静分离原理

服务端接收来自客户端的请求中,既有静态资源也有动态资源,静态资源有Nginx提供服务,动态资源Nginx转发至后端。
在这里插入图片描述

三、Nginx配置反向代理主要参数

配置后端服务器池,以提供响应数据

upstream 服务器名 {
    
    }

配置将访问请求转发给后端服务器池名

proxy_pass http://服务器名

四、模拟实验

Nginx作为负载均衡器,Tomcat作为应用服务器
服务器安装步骤请参考:
Nginx网站服务
Tomcat网站服务
所需软件包

主机 操作系统 IP地址 软件包
Nginx Server CentOS7 192.168.184.10 nginx-1.12.0.tar.gz
Tomcat Server1 CentOS7 192.168.184.20 apache-tomcat-9.0.16.tar.gz、jdk-8u201-linux-x64.rpm
Tomcat Server2 CentOS7 192.168.184.30 apache-tomcat-9.0.16.tar.gz、jdk-8u201-linux-x64.rpm

4.1 配置Tomcat Server1、Server2

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 test2 page</title>
</head>
<body>
<% out.println("此为动态页面:test1");%>
</body>
</html>

vim /usr/local/tomcat/conf/server.xml
<Host name="server1" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
        <Context docBase="/usr/local/tomcat/webapps/test" path="" reloadable="true" />
</Host>

/usr/local/tomcat/bin/shutdown.sh 
/usr/local/tomcat/bin/startup.sh 

server1
在这里插入图片描述
在这里插入图片描述

server2
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

4.2 配置Nginx server

echo '<html><body><h1>此为静态页面</h1></body></html>' > /usr/local/nginx/html/index.html
mkdir /usr/local/nginx/html/TEST
cd /usr/local/nginx/html/TEST/     #直接把图片拖入这个目录下

在这里插入图片描述

#gzip on;
   upstream tomcat_server {
    
    
	        server 192.168.153.20:8080 weight=1;
         	server 192.168.153.30:8080 weight=1;
   }
server {
    
    
	listen 80;
	server_name www.wt.com;

	charset utf-8;
#access_log  logs/host.access.log  main;
	
#配置Nginx处理动态页面请求,将 .jsp文件请求转发到Tomcat 服务器处理
	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;  
	}
	
	location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|css)$ {
    
    
		root /usr/local/nginx/html/TEST;
		expires 10d;
	}
......

在这里插入图片描述
在这里插入图片描述

systemctl restart nginx          #重启nginx服务

在这里插入图片描述

如果浏览器无法访问可能是因为nginx服务关了,nginx 打开服务即可

4.3 浏览器访问测试

测试静态页面效果
浏览器访问 http://192.168.153.10/
浏览器访问 http://192.168.153.10/sea.jpg

在这里插入图片描述
在这里插入图片描述

测试负载均衡效果,不断刷新浏览器测试
浏览器访问 http://192.168.153.10/wt/index.jsp

在这里插入图片描述

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_51613313/article/details/114576737