Nginx 反向代理实现 Tomcat 高可用性负载均衡详解

Tomcat 简介

Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun和其他一些公司及个人共同开发而成。

Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP程序的首选。

Tomcat和Nginx、Apache(httpd)、lighttpd等Web服务器一样,具有处理HTML页面的功能,另外它还是一个Servlet和JSP容器,独立的Servlet容器是Tomcat的默认模式。不过,Tomcat处理静态HTML的能力不如Nginx/Apache服务器。

目前Tomcat最新版本为9.0。Java容器还有resin、weblogic等。

Tomcat目录结构

Tomcat 一级目录

[root@rs1 ~]# cd /usr/local/tomcat/
[root@rs1 tomcat]# tree -L 1
.
├── bin 		#存放tomcat管理脚本
├── conf 		#tomcat 配置文件存放目录
├── lib 		#web应用调用的jar包存放路径
├── LICENSE
├── logs 		#tomcat日志存放目录,catalina.out为主要输出日志
├── NOTICE
├── RELEASE-NOTES
├── RUNNING.txt
├── temp 		#存放临时文件
├── webapps 	#web程序存放目录
└── work 		#存放编译产生的.java 与 .class文件

Tomcat 二级目录

[root@localhost ~]# cd /usr/local/tomcat/webapps
[root@localhost webapps]# tree -L 1
.
├── docs 			#tomcat 帮助文档
├── examples 		#web应用实例
├── host-manager 	#主机管理
├── manager 		#管理
└── ROOT 			#默认站点根目录[root@localhost ~]# cd /usr/local/tomcat/conf
[root@localhost conf]# tree -L 1
.
├── Catalina
├── catalina.policy
├── catalina.properties
├── context.xml
├── logging.properties
├── logs
├── server.xml 			#tomcat 主配置文件
├── server.xml.bak
├── server.xml.bak2
├── tomcat-users.xml 	#tomcat 管理用户配置文件
├── tomcat-users.xsd
└── web.xml

tomcat 安装

安装java环境:

[root@rs1 ~]# yum install java-1.8.0-openjdk.x86_64 -y

1、下载tomcat源码软件包
在这里插入图片描述

2、解压源码包并指定解压的路径

[root@rs1 ~]# tar zxf apache-tomcat-9.0.93.tar.gz -C /usr/local/

在这里插入图片描述

3、生成并编辑tomcat配置文件

[root@rs1 conf]# vim /usr/local/apache-tomcat-9.0.93/conf/tomcat.conf
JAVA_HOME=/etc/alternatives/jre_openjdk

在这里插入图片描述
编辑配置文件内容,指定jdk路径

4、启用 java-tomcat 服务和8080端口

[root@rs1 ~]# /usr/local/apache-tomcat-9.0.93/bin/startup.sh 

在这里插入图片描述

5、生成tomcat用户

[root@rs1 ~]# useradd -s /sbin/nolongin -M tomcat

6、将tomcat用户和用户组映射至tomcat目录

[root@rs1 ~]# chown -R tomcat.tomcat /usr/local/apache-tomcat-9.0.93

在这里插入图片描述

7、生成并编辑自启动文件

[root@rs1 ~]# vim /lib/systemd/system/tomcat.service[Unit]
Description=Tomcat
#After=syslog.target network.target remote-fs.target nss-lookup.target
After=syslog.target network.target
[Service]
Type=forking
EnvironmentFile=/usr/local/tomcat/conf/tomcat.conf
ExecStart=/usr/local/tomcat/bin/startup.sh
ExecStop=/usr/local/tomcat/bin/shutdown.sh
PrivateTmp=true
User=tomcat
Group=tomcat
[Install]
WantedBy=multi-user.target

在这里插入图片描述

8、开机自启动tomcat服务

[root@rs1 ~]# systemctl enable --now tomcat

在这里插入图片描述

tomcat 负载均衡

动态服务器的问题,往往就是并发能力太弱,往往需要多台动态服务器一起提供服务。如何把并发的压力分摊,这就需要调度,采用一定的调度策略,将请求分发给不同的服务器,这就是Load Balance负载均衡。

当单机Tomcat,演化出多机多级部署的时候,一个问题便凸显出来,这就是Session。而这个问题的由来,都是由于HTTP协议在设计之初没有想到未来的发展。

常见的部署方式

1、standalone模式,Tomcat单独运行,直接接受用户的请求,不推荐。

2、反向代理,单机运行,提供了一个Nginx作为反向代理,可以做到静态由nginx提供响应,动态jsp代理给Tomcat

​ LNMT:Linux + Nginx + MySQL + Tomcat

​ LAMT:Linux + Apache(Httpd)+ MySQL + Tomcat

3、前置一台Nginx,给多台Tomcat实例做反向代理和负载均衡调度,Tomcat上更适合部署纯动态页面

​ LNMT:Linux + Nginx + MySQL + Tomcat

4、多级代理

​ LNNMT:Linux + Nginx + Nginx + MySQL + Tomcat

在这里插入图片描述

Nginx 反向代理实现 Tomcat

在这里插入图片描述

利用nginx反向代理功能,实现图中的代理功能,将用户请求全部转发至指定的同一个tomcat主机

利用nginx指令proxy_pass 可以向后端服务器转发请求报文,并且在转发时会保留客户端的请求报文中的host首部

location ~ \.jsp$ {proxy_pass http://172.25.254.10:8080;
}#访问网页时必须以 “jsp” 结尾,例如:www.tym.com/test.jsp

Tomcat 负载均衡部署

tomcat 部署

将网页文件拷贝至默认发布页目录下

[root@rs1 ~]# cd /usr/local/tomcat/webapps/ROOT/

在这里插入图片描述

Nginx 部署

在子配置文件内编辑,当一台主机宕机时,自动切换至另一台主机上

在这里插入图片描述

效果演示
在这里插入图片描述

tomcat 高可用

HTTP 的无状态,有连接,短连接

无状态

指的是服务器端无法知道2次请求之间的联系,即使是前后2次请求来自同一个浏览器,也没有任何数据能够判断出是同一个浏览器的请求。后来可以通过cookie、session机制来判断。

​ (1)浏览器端第一次HTTP请求服务器端时,在服务器端使用session这种技术,就可以在服务器端产生一个随机值即SessionID发给浏览器端,浏览器端收到后会保持这个SessionID在Cookie当中,这个Cookie值一般不能持久存储,浏览器关闭就消失。浏览器在每一次提交HTTP请求的时候会把这个SessionID传给服务器端,服务器端就可以通过比对知道是谁了

​ (2)Session通常会保存在服务器端内存中,如果没有持久化,则易丢失

​ (3)Session会定时过期。过期后浏览器如果再访问,服务端发现没有此ID,将给浏览器端重新发新的SessionID

​ (4)更换浏览器也将重新获得新的SessionID

有连接

是因为它基于TCP协议,是面向连接的,需要3次握手、4次断开。

短连接

Http 1.1之前,都是一个请求一个连接,而Tcp的连接创建销毁成本高,对服务器有很大的影响。所以,自Http 1.1开始,支持keep-alive,默认也开启,一个连接打开后,会保持一段时间(可设置),浏览器再访问该服务器就使用这个Tcp连接,减轻了服务器压力,提高了效率。

服务器端如果故障,即使Session被持久化了,但是服务没有恢复前都不能使用这些SessionID。

如果使用HAProxy或者Nginx等做负载均衡器,调度到了不同的Tomcat上,那么也会出现找不到SessionID的情况

Memcached 简介

Memcached 只支持能序列化的数据类型,不支持持久化,基于Key-Value的内存缓存系统;

memcached虽然没有像redis所具备的数据持久化功能,比如RDB和AOF都没有,但是可以通过做集群同步的方式,让各memcached服务器的数据进行同步,从而实现数据的一致性,即保证各memcached的数据是一样的,即使有任何一台 memcached 发生故障,只要集群中有一台 memcached 可用就不会出现数据丢失,当其他memcached 重新加入到集群的时候,可以自动从有数据的memcached 当中自动获取数据并提供服务。

Memcached 借助了操作系统的 libevent 工具做高效的读写。libevent是个程序库,它将Linux的epoll、BSD类操作系统的kqueue等事件处理功能封装成统一的接口。即使对服务器的连接数增加,也能发挥高性能。

memcached使用这个libevent库,因此能在Linux、BSD、Solaris等操作系统上发挥其高性能;

Memcached 支持最大的内存存储对象为1M,超过1M的数据可以使用客户端压缩或拆分报包放到多个key中,比较大的数据在进行读取的时候需要消耗的时间比较长,memcached 最适合保存用户的session实现session共享;

Memcached存储数据时, Memcached会去申请1MB的内存, 把该块内存称为一个slab, 也称为一个page;

Memcached 支持多种开发语言,包括:JAVA,C,Python,PHP,C#,Ruby,Perl等

配置参数

set
add
replace
get
delete#前三个命令是用于操作存储在 memcached 中的键值对的标准修改命令,都使用如下所示的语法:
command <key> <flags> <expiration time> <bytes <value>#参数说明如下:
command set/add/replace
key 				#key 用于查找缓存值flags 				#可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息expiration time 	#在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)bytes 				#在缓存中存储的字节数value 				#存储的值(始终位于第二行)add key flags exptime bytes	#增加key,过期时间为秒,bytes为存储数据的字节数

Memcached 配置

1、下载memcached软件

[root@rs2 ~]# yum install memcached -y

2、编辑 memcached 配置文件

[root@rs2 ~]# vim /etc/sysconfig/memcached 

在这里插入图片描述

3、开启服务开机自启动

[root@rs2 ~]# systemctl enabl --now memcached[root@rs2 ~]# netstat -natlupe | grep memcached
#查看其服务端口号是否开启

在这里插入图片描述

session 共享服务器

在这里插入图片描述

msm(memcached session manager)提供将Tomcat的session保持到memcached,实现高可用

支持Tomcat的 6.x、7.x、8.x、9.xTomcat的Session管理类,Tomcat版本不同memcached-session-manager-2.3.2.jarmemcached-session-manager-tc9-2.3.2.jarSession数据的序列化、反序列化类官方推荐kyro在webapp中WEB-INF/lib/下驱动类memcached(spymemcached.jar)Redis(jedis.jar)

tomcat 配置

1、tomcat1 和 memcached1 可部署在一台主机上,tomcat2 和 memcached2也可部署在同一台主机上

2、当新用户发请求到Tomcat1时, Tomcat1生成session返回给用户的同时,也会同时发给memcached2备份;即Tomcat1 session为主session,memcached2 session为备用session,使用memcached相当于备份了一份Session

3、如果Tomcat1发现memcached2 失败,无法备份Session到memcached2,则将Sessoin备份存放在memcached1中

1、需要下载的软件包

kryo-3.0.3.jar
asm-5.2.jar
objenesis-2.6.jar
reflectasm-1.11.9.jar
minlog-1.3.1.jar
kryo-serializers-0.45.jar
msm-kryo-serializer-2.3.2.jar
memcached-session-manager-tc9-2.3.2.jar
spymemcached-2.12.3.jar
memcached-session-manager-2.3.2.jar

2、将需要下载的软件包移动至 tomcat 下的 lib 目录

[root@rs1 ~]# cd /usr/local/tomcat/lib/

在这里插入图片描述

3、修改配置文件内容

[root@rs1 ~]# vim /usr/local/tomcat/conf/context.xml<Manager	className="de.javakaffee.web.msm.MemcachedBackupSessionManager"memcachedNodes="n1:172.25.254.10:11211,n2:172.25.254.20:11211"failoverNodes="n1"requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"
/>

在这里插入图片描述
编辑内容:
在这里插入图片描述

Ngixn 配置

修改 Nginx 子配置文件
在这里插入图片描述

效果演示
在tomcat2上输入数据
在这里插入图片描述

tomcat2 宕机时,自动切换到tomcat1,tomcat2上输入的数据保留
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/409477.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【OpenCV】 中使用 Lucas-Kanade 光流进行对象跟踪和路径映射

文章目录 一、说明二、什么是Lucas-Kanade 方法三、Lucas-Kanade 原理四、代码实现4.1 第 1 步&#xff1a;用户在第一帧绘制一个矩形4.2 第 2 步&#xff1a;从图像中提取关键点4.3 第 3 步&#xff1a;跟踪每一帧的关键点 一、说明 本文针对基于光流法的目标追踪进行叙述&am…

影响我国地理信息产业发展最大的阻碍是?

我国地理信息产业发展迅速&#xff0c;大家可以从业内协会领导或院士报告中了解相关数据&#xff0c;每年地理信息产业规模多少多少亿&#xff0c;增长多少多少百分比&#xff0c;在成绩喜人的同时&#xff0c;当然专家或院士从更高层面分析了当前地理信息产业所遇到的困难与阻…

如何使用ssm实现基于ssm的“游侠”旅游信息管理系统

TOC ssm190基于ssm的“游侠”旅游信息管理系统jsp 绪论 1.1 研究背景 当前社会各行业领域竞争压力非常大&#xff0c;随着当前时代的信息化&#xff0c;科学化发展&#xff0c;让社会各行业领域都争相使用新的信息技术&#xff0c;对行业内的各种相关数据进行科学化&#x…

如何用Java SpringBoot和Vue搭建高效的OA办公管理系统?

✍✍计算机编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡ Java实战 |…

Leetcode 46.全排列

注意的点&#xff1a; 1、回溯本质就是搜索树的树枝&#xff0c;维护三个核心变量&#xff1a;path&#xff08;需要恢复现场&#xff09;&#xff0c;visited&#xff08;需要恢复现场&#xff09;&#xff0c;以及res 解法&#xff1a;回溯算法 class Solution:def permut…

linux死锁问题和cpu使用率过高问题排查

1、问题共同点 死锁问题和cpu使用率过高都是需要我们找出对应的问题线程。 死锁问题需要我们找出哪两个线程出现了死锁情况。 cpu使用率过高需要我们找出哪个或哪些线程占用了大量的cpu。 2、命令排查 2.1、查看机器上的Java进程 jcmd或 jps2.2、查看对应Java进程的线程级别…

简单的jar包重打包Failed to get nested archive for entry 报错处理

简单的jar包重打包Failed to get nested archive for entry 报错处理 1. 需求 公司有一个后端项目&#xff0c;项目已经打好了jar包&#xff0c;现在我们发现jar包依赖的子包有问题&#xff0c;其中的一个mybatis xml文件查询数据不正确&#xff0c;我们需要替换项目&#xf…

Java语言程序设计基础篇_编程练习题*17.4 (将文本文件转換为UTF格式)

目录 题目&#xff1a;*17.4 (将文本文件转換为UTF格式) 习题思路 代码示例 输出结果 题目&#xff1a;*17.4 (将文本文件转換为UTF格式) 编写一个程序&#xff0c;每次从文本文件中读取多行字符&#xff0c;并将这些行字符以UTF-8字符串格式写入一个二进制文件中…

Jenkins 2.346.1完整搭建及项目部署安装

java version "1.8.0_202" 1.安装 官网下载war包直接启动&#xff0c;比较简单&#xff0c; linux命令 &#xff1a; wget https://mirrors.jenkins.io/war-stable/2.346.1/jenkins.war 2.启动命令 nohup java -jar jenkins.war --httpPort8777 --prefix/jenkin…

整套厨帽检测算法样本、模型、源码和厨帽算法识别应用方案介绍

厨帽检测算法的应用方案主要涉及技术选型、硬件配置、软件集成、部署与监控以及应对实际挑战等多个方面。以下是一个详细的应用方案概述&#xff1a; 一、技术选型 深度学习技术&#xff1a;厨帽检测算法主要基于深度学习技术&#xff0c;特别是卷积神经网络&#xff08;CNN&…

“解锁进程间高效沟通,Linux IPC是你的关键钥匙!“#Linux系统编程之进程间通信【下】

"解锁进程间高效沟通&#xff0c;Linux IPC是你的关键钥匙&#xff01;"#Linux系统编程之进程间通信【下】 前言预备知识一、 共享内存概述1.1 共享内存概述简图 二、 共享内存编程实战2.1 共享内存介绍2.1.1 共享内存的特点 2.2 共享内存几个重要API介绍2.2.1 shmge…

三品船舶PLM解决方案详情 三品PLM软件在船舶制造行业应用优势

自2024年起&#xff0c;船舶行业PLM&#xff08;产品全生命周期管理&#xff09;技术步入关键发展阶段。国产化工业软件领域积极倡导生态合作&#xff0c;推广统一技术底座下的合作开发模式&#xff0c;整合国内外成熟的工业软件技术与应用资源&#xff0c;旨在全面提升国内船舶…

webflux源码解析(3)-reactor netty

目录 1.连接的状态2.reactor netty中的连接状态3. webflux中的io处理4.总结 为什么webflux在io密集型的场景能有效的提升系统吞吐量呢&#xff1f; 是因为它使用的是响应式编程&#xff0c;使用的是NIO&#xff0c;但这里的响应式、nio到底是怎么样的呢&#xff1f;响应式编程上…

vue的for循环不建议用index作为key

我们页面总有一些相似的&#xff0c;我们想用循环渲染&#xff0c;根据对象数组结构进行渲染&#xff0c;这是不是很熟悉的场景。这时候我们需要有一个唯一的key绑定在循环渲染的元素上&#xff0c;一般情况下我们会用id&#xff0c;因为id是唯一的。然而有些页面要循环的数据&…

生鲜O2O系统app源码开发之功能解析:构建高效便捷的生鲜电商生态

随着互联网技术的飞速发展和消费者对于生活品质要求的日益提升&#xff0c;生鲜电商行业迎来了前所未有的发展机遇。生鲜O2O&#xff08;Online to Offline&#xff09;系统作为连接线上购物与线下服务的关键桥梁&#xff0c;其源码开发不仅关乎平台的稳定运行&#xff0c;更直…

【XML详解】

XML基本概念 XML&#xff08;全称EXtensible Markup Language&#xff0c;可扩展标记语言&#xff09;&#xff1a;是一种用于存储和传输数据的标记语言&#xff0c;通过标签&#xff08;tags&#xff09;来定义数据的结构和含义。数据格式&#xff1a;XML本质上是一种数据的格…

盘点15款主流客户管理系统,助力企业选型!

本文将盘点15款主流客户管理系统&#xff1a; 简道云、纷享销客、销售易、HubSpot、Zoho CRM、SAP CRM、Oracle CRM、金蝶云星空 CRM、用友 CRM、悟空 CRM、Salesforce、Microsoft Dynamics 365、亿客 CRM、八百客 CRM、CloudCC CRM。 在当今的商业环境中&#xff0c;客户管理系…

记一次将请求改为协商缓存的艰难过程

简单回顾一下前端缓存策略 ⛏️ 强缓存&#xff1a;在请求头规定的max-age和expirse过期之前直接读取本地缓存的资源&#xff0c;如果已经过期则调用协商缓存协商缓存&#xff1a;也叫弱缓存&#xff0c;以下都称为协商缓存。协商缓存是缓存过期&#xff0c;刷新缓存时间或者文…

JVM - 1.类加载子系统

1.类加载子系统 1.作用 1.负责从文件系统或网络中加载字节码(.class)文件&#xff0c;即将物理磁盘上的字节码文件加载到内存中&#xff0c;生成供程序使用的类对象 2.字节码文件要求在文件开头有特定的文件标识(CA FE BA BE)3.类加载器(ClassLoader)只负责字节码文件的加载&am…

pdf文件渲染到canvas

1、jQuery 2、Fabric.js Fabric.js是一个对canvas进行封装的Javascript库&#xff0c;主要的功能包括在canvas上创建和填充图形&#xff0c;比如矩形、圆形、多边形&#xff1b;生成的图像自带缩放、旋转、拖拽等功能。 3、PDF.js PDF.js 是一个使用 HTML5 构建的便携式文档格式…