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

news/2024/7/10 0:34:42 标签: nginx, tomcat, 负载均衡, 动静分离

Nginx+Tomcat

  • 一、概述
  • 二、原理
    • 2.1 Nginx处理静态页面的优势
    • 2.2 Nginx动静分离原理
  • 三、Nginx配置反向代理主要参数
  • 四、模拟实验
    • 4.1 配置Tomcat Server1、Server2
    • 4.2 配置Nginx server
    • 4.3 浏览器访问测试

一、概述

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 ServerCentOS7192.168.184.10nginx-1.12.0.tar.gz
Tomcat Server1CentOS7192.168.184.20apache-tomcat-9.0.16.tar.gz、jdk-8u201-linux-x64.rpm
Tomcat Server2CentOS7192.168.184.30apache-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

在这里插入图片描述

在这里插入图片描述


http://www.niftyadmin.cn/n/1075123.html

相关文章

OpenStack 环境配置(图文详解)

OpenStack 环境配置一、虚拟机资源配置二、基础环境配置(所有节点)2.1 主机名2.2 防火墙及安全机制2.3 配置在线源2.4 安装基础环境依赖包2.5 修改网卡配置文件2.6 配置主机映射文件2.7 免交互2.8 配置DNS2.9 配置控制节点时间同步2.10 设置周期性任务三、系统环境配置(ct)3.1 …

iOS 多线程之线程锁Swift-Demo示例总结

线程锁是什么 在前面的文章中总结过多线程&#xff0c;总结了多线程之后&#xff0c;线程锁也是必须要好好总结的东西&#xff0c;这篇文章构思的时候可能写的东西得许多&#xff0c;只能挤时间一点点的慢慢的总结了&#xff0c;知道了线程之后要了解线程锁就得先了解一下什么是…

OpenStack组件部署之Keystone

Keystone部署前言一、创建数据库实例与数据库用户二、安装、配置keystone、数据库、Apache2.1 安装keystone、httpd、mod_wsgi2.2 初始化认证服务数据库2.3 配置bootstrap身份认证服务2.4 配置Apache HTTP服务器2.5 创建配置文件2.6 开启服务2.7 配置管理员账户的环境变量三、创…

Netty--使用TCP协议传输文件

简介&#xff1a; 用于将文件通过TCP协议传输到另一台机器&#xff0c;两台机器需要通过网络互联。 实现&#xff1a; 使用Netty进行文件传输&#xff0c;服务端读取文件并将文件拆分为多个数据块发送&#xff0c;接收端接收数据块&#xff0c;并按顺序将数据写入文件。 工程结…

OpenStack组件部署之Glance

Glance一、Glance概述1.1 镜像服务1.2 Images API的版本1.3 镜像格式1.4 镜像格式1.5 镜像状态1.6 访问权限1.7 架构图1.8 工作流程1.9 小结二、Glance服务部署2.1 创建数据库实例和数据库用户2.2 创建用户、修改配置文件三、部署思路一、Glance概述 镜像服务在OpenStack中的项…

C#读写txt文件的两种方法介绍[转]

C#读写txt文件的两种方法介绍1.添加命名空间 System.IO; System.Text; 2.文件的读取 (1).使用FileStream类进行文件的读取&#xff0c;并将它转换成char数组&#xff0c;然后输出。 byte[] byData new byte[100];char[] charData new char[1000]; public void Read() { try {…

优秀程序员应具备的15个特性

1、分享尽可能地使用开源&#xff0c;并且如果有能力的话也可以把自己的成果分享给大家。整个社会的智慧结晶肯定比一些大公司自管自闭门造车要好。 2、公平的心态不要以为你的选择就是唯一能奏效的&#xff0c;试试其他技术、框架、方法和建议&#xff0c;也许其他的选择比你原…

OpenStack组件部署之Placement

OpenStack-Placement一、创建数据库实例和数据库用户二、创建Placement服务用户和API的endpoint三、安装placement服务四、修改Apache配置文件五、测试Placement提供了placement-apiWSGI脚本&#xff0c;用于与Apache&#xff0c;nginx或其他支持WSGI的Web服务器一起运行服务(通…