常见apache+tomcat应用架构与负载均衡| 学习笔记

本文涉及的产品
网络型负载均衡 NLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
简介: 快速学习常见apache+tomcat应用架构与负载均衡。

开发者学堂课程【企业Web常用架构LAMP-LNMP实战常见apache+tomcat应用架构与负载均衡】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/385/detail/4830


常见apache+tomcat应用架构与负载均衡

 

目录:

一、常用的LAMT应用架构

二、tomcat 的安装配置以及jk模块的配置  

三、LAMT负载均衡架构的实现

四、具体使用流程

  

一、常用的LAMT应用架构

LAMT 的 T 就是 TomCat 的意思,此结构在传统行业中使用较多,基于 JAVA 环境或 j2e 架构

image.png

企业最常用的架构,Apache 与 Tomcat 结合架构,分为两台机器,A主机上安装Apache,B主机安装 Tomcat ,通过 jk 模块进行通信,部署在一台主机上也可以完成

Apache:

高性能的 http 服务器,或者 web 服务器,主要特殊为出色的处理静态数据,例如图片,视频等,通过 apachec 处理

Tomcat 设计初衷就是去解析 jsp 动态程序,虽然也可以解析处理静态数据,性能会差

apache +jk+tomcat 优点:
apache 处理静态请求性能出色

tomcat 处理动态请求更为专业
apache +tomcat 的目的是为了实现网页动、静分离。完整处理web资源,通过Apache 代理工作实现

jk 模块实现 Apache 与 Tomcat 交互,连接作用

为什么整合 tomcat 和 apache ?

Tomcat  处理静态比较好,apache 处理静态比较好,静态和动态结合处理 web 服务器资源

结合方式:apache 代理功能实现和jk模块

 

二、tomcat的安装配置以及jk模块的配置

JK 模块:  Apache  和 Tomcat 连接器
实现连接器模式很多, jk2 开发人员停止更新
两个模块可供选择: mod_ jk2 和 mod_ jk, mod. jk2 模块是比较早的一种连接器,在静页面过滤上可以使用正则表达式,因此使用配置灵活,但是 mod_jk2 模块现在已经没发人员支持了。因此推荐 mod.jk 模块,最新 mod_jk 版本为1.2.41.
1.JK模块安装

http://archive.apache.org/dist/tomcat/tomcat-connectors/

image.png

安装 jk 模块需提前安装 apache

源码安装:

#解压安装包
[root@webserverlocal]#tar zxvf

tomcat-connectors-1.2.40-src.tar.gz
#到源码目录下 native,buildconf.sh 是配置环境的文件
[root@webserverlocal]#cdtomcat-connectors-1.2.40src/native

#赋权给 buildconf.sh
[root@webservernative]#chmod755buildconf.sh

#输出可执行脚本文件
[root@webservernative]#./buildconf.sh

#这里指定的是 apache 安装目录中 apxs 的位置
[root@webservernative]#/configure --with-apxs=/usr/local/apache2/bin/apxs

#make编译
[root@websevernative]#make
[root@webservernative]#makeinstall

实现JK模块添加到 Apache 下

#查看

[root@hadoopnative]#cd_/usr/1oca1/apache2/modu7

#所需文件 mod_jk.so

[root@hadoop moduTes]#ll mod_jk.so

-rwxr-xr-x i root root 1140556~Mar3 16:43 mod_jk.so 

把mod_jk.so动态加载到Apache配置文件中

加载方式:

LoadMoule jk_module modules/mod_jk.so

加载完成后实现 jk 模块与 tomcat 通信

2. Tomecat安装

下载 Tomcat

1)打开上面的地址,进入官网

2)选择需要的版本进行加载

3)下载之后直接解压,事实上 tomcat 不需要安装,但需要配置

4)打开文件夹,可以先了解一下各个子文件夹的作用
bin:放一些可执行的脚本文件,比如我们要启动和关闭 tomcat 的可执行文件也在里面
conf:放一些配置文件
lib:tomcat 的依赖 jar 包
logs:存放日志
temp:存放临时文件
webapps:存放我们的网站的

5)然后启动我们的 tomcat,打开 bin 文件夹,找到 startup.bat 文件并打开

6)启动之后,访问我们的本机的8080端口

在浏览器的网址栏中输入 localhost:8080

注意:Tomcat 需要配置 java 环境变量,写入文件中,不受系统环境变量影响

在启动 tomcat 文件中,写入:

Export JAVA_HOME=jdk 安装路径

部署完毕启动 tomcat:

[root@hadoop bin]# ./startup.sh

查看启动状态,切换到 tomcat/logs 目录下

[root@hadoop logs]# vim catalina.out

image.png


三、LAMT负载均衡架构的实现

负载均衡常用架构模式的使用

配置实现图例架构:

image.png

最后端有很多个 tomcat ,后端调度多个 tomcat 的环境架构

具体实现:

心跳机制:

服务端定时主动的去与要监控状态的客户端(或者叫其他系统)通信,询问当前的某种状态,客户端返回状态信息,客户端没有返回或返回错误、失效信息、则认为客户端已经宕机

实现 Apache+JK 模块,后端调用多个 Tomcat 方式生产

apache 下增加:
#核心配置文件,单机和负载均衡配置
[root@hadoop ]#JkWorkersFile/usr/local/apache2/conf/workers.properties

workers.properties文件:

#server列表,工作列表,有多少个后端节点在运行

worker.list = controller,tomcat1,tomcat2

========tomcat============

#ajp13端口号,在tomcat 下server.xml配置,默认8009

#tomcat1的定义,端口属性

worker.tomcat1.port=8009

#tomcat的主机地址,如不为本机,请填写ip地址

worker.tomcat1.host=localhost  

//type类型有两种,ajp12和ajp13,实现通信

worker.tomcat1.type=ajp13

#server的加权比重,值越高,分得的请求越多

worker.tomcat1.lbfactor=1  

========tomcat2=============

worker.tomcat2.port=8109

#ajp13 端口号,在 tomcat 下 server.xml 配置,默认8009

#tomcat 的主机地址,如不为本机,请填写ip地址

worker.tomcat2.host=localhost

worker.tomcat2.type=ajp13 

#server 的加权比重,值越高,分得的请求越多,有负载均衡功能权重才生效

worker.tomcat2.lbfactor=1 

#========controller,负载均衡控制器========

#lb 定义负载均衡

worker.controller.type=lb 

#指定分担请求的 tomcat

worker.controller.sticky_session=1

#指定 balance 节点个数参与负载均衡,使用逗号分割

worker.controller.balanced_workers=tomcat1,tomcat2

#指定 session 的负载均衡

Worker.controller.sticky_session=1
JkMountFile /usr/local/apache2/conf/uriworkermap.propertis JkLogFile/usr/local/apache2/logs/mod_jk.logJkLogLevelinfoJkLogStampformat"[%a%b%d%H:%M:%S%Y]"

uriworkermap.properties 文件

#主要作用:实现动静分离,通过正则表达式实现

#以.jsp文件分配给控制器

/*.jsp=controller

#所有以*.jsp文件全部交给 tomcat1 或2

#不是.jpg等结尾,不交给 tomcat 处理,最终交给 Apache 处理

通过此匹配规则实现动静分离,最终加载到列表中去,映射文件实现交给负载均衡器
!/*.jpg=controller

!/*.gi=controller

!/*.png=controller

!/*.bmp=controller

!/*.html=controller

!/*.htm=controller

!/*.swf=controller

!/*.css=controller

!/*.js=controller

 

四、具体使用

检查配置文件:

1. workers.properties 

2.Httpd.conf

[root@hadoop bin]# vim httpd.conf

JkworkersFile kusr/loca1/apache2/conf/workers.properties

JkMountFi1eusr/1oca1/apache2/conf/uriworkermap.propertieskLogFile /usr/loca1/apache2/logs/mod_jk.1og

JkLogLeve7info

JkLogstampformat "[%a %b %d %H:%M:%S %Y]“

定义日志文件和work文件

3.Uriworkermap.properties

映射文件,负载均衡器处理文件

在本机启动 tomcat 端口

[root@hadoop conf]# ps =ef|grep java

查看到 tomcat 路径

第二台机器启动 tomacat

[root@hadoop conf]# ps =ef|grep java

第二台机器命令为 tomcat81 ,区分负载均衡在那一台机器

测试:

1. 制作一个 info.jsp 文件,放置到 tomcat 默认目录下 /webapps/ROOT ,探测性质文件,探测本机 IP 和路径信息

在 tomcat1,tomcat2 或其他机器上也放置相同的文件

2.访问

Ip 地址 /info.jsp

探测文件可以访问,查看访问的机器,找到 tomcat 路径

Jsp 交给 tomcat 处理,若文件不存在,tomcat 将会保存

image.png

服务器端口80

客户端端口5O605

客户端IP 10.1.0.10

web服务器 Aache Tomcatf8.0.32

操作系统 Linuxunknown Ver : 2.6.32-279.el6. x86_64

服务器时间 mar 3,2016 10: 16:25 PM

CPU信息 am dB4

磁盘分区 /

用户当前工作目录 usr/localf/tomcat8/logs

本文件路径/usri/local/tomcat8/weLpps/R00T/info.jsp

Jara相关信息

JDK版本 1.7.0_45

Serrlet版本 3.1

JDK安装路径/usr/ java/ jdk1.7.0_45/jre

编码 UTF-8

JAVA类路径/usr/local/tomcat8/bin/bootstrap.jar:/ usr/local/tomcat8/bin/ tomcat-juli.jar

不断刷新页面,测试动静分离

测试图片:

apache_pb22.png

image.png图片是 Apachech 处理,jsp文件是 tomcat 处理,实现负载均衡随机 tomcat1 2节点中实现负载均衡

172.16.212.232/apache_pb221.png

更改文件名,查看输出报错,即可观察到文件是 apache 处理还是 tomcat 处理

image.png

通过此类方式判断 apache 和 tomcat 动静分离,不停刷新 jsp 文件实现负载均衡功能

J2e 架构通过此架构比较稳定

反向代理功能做不到严格匹配,没做到细化文件后缀。

相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
26天前
|
消息中间件 数据挖掘 Kafka
Apache Kafka流处理实战:构建实时数据分析应用
【10月更文挑战第24天】在当今这个数据爆炸的时代,能够快速准确地处理实时数据变得尤为重要。无论是金融交易监控、网络行为分析还是物联网设备的数据收集,实时数据处理技术都是不可或缺的一部分。Apache Kafka作为一款高性能的消息队列系统,不仅支持传统的消息传递模式,还提供了强大的流处理能力,能够帮助开发者构建高效、可扩展的实时数据分析应用。
69 5
|
2月前
|
存储 SQL 缓存
快手:从 Clickhouse 到 Apache Doris,实现湖仓分离向湖仓一体架构升级
快手 OLAP 系统为内外多个场景提供数据服务,每天承载近 10 亿的查询请求。原有湖仓分离架构,由离线数据湖和实时数仓组成,面临存储冗余、资源抢占、治理复杂、查询调优难等问题。通过引入 Apache Doris 湖仓一体能力,替换了 Clickhouse ,升级为湖仓一体架构,并结合 Doris 的物化视图改写能力和自动物化服务,实现高性能的数据查询以及灵活的数据治理。
快手:从 Clickhouse 到 Apache Doris,实现湖仓分离向湖仓一体架构升级
|
2月前
|
安全 网络协议 应用服务中间件
AJP Connector:深入解析及在Apache HTTP Server中的应用
【9月更文挑战第6天】在Java Web应用开发中,Tomcat作为广泛使用的Servlet容器,经常与Apache HTTP Server结合使用,以提供高效、稳定的Web服务。而AJP Connector(Apache JServ Protocol Connector)作为连接Tomcat和Apache HTTP Server的重要桥梁,扮演着至关重要的角色
79 2
|
21天前
|
存储 SQL Apache
Apache Doris 开源最顶级基于MPP架构的高性能实时分析数据库
Apache Doris 是一个基于 MPP 架构的高性能实时分析数据库,以其极高的速度和易用性著称。它支持高并发点查询和复杂分析场景,适用于报表分析、即席查询、数据仓库和数据湖查询加速等。最新发布的 2.0.2 版本在性能、稳定性和多租户支持方面有显著提升。社区活跃,已广泛应用于电商、广告、用户行为分析等领域。
Apache Doris 开源最顶级基于MPP架构的高性能实时分析数据库
|
25天前
|
负载均衡 监控 算法
论负载均衡技术在Web系统中的应用
【11月更文挑战第4天】在当今高并发的互联网环境中,负载均衡技术已经成为提升Web系统性能不可或缺的一环。通过有效地将请求分发到多个服务器上,负载均衡不仅能够提高系统的响应速度和处理能力,还能增强系统的可扩展性和稳定性。本文将结合我参与的一个实际软件项目,从项目概述、负载均衡算法原理以及实际应用三个方面,深入探讨负载均衡技术在Web系统中的应用。
49 2
|
1月前
|
存储 分布式计算 druid
大数据-149 Apache Druid 基本介绍 技术特点 应用场景
大数据-149 Apache Druid 基本介绍 技术特点 应用场景
59 1
大数据-149 Apache Druid 基本介绍 技术特点 应用场景
|
1月前
|
SQL 存储 分布式计算
大数据-157 Apache Kylin 背景 历程 特点 场景 架构 组件 详解
大数据-157 Apache Kylin 背景 历程 特点 场景 架构 组件 详解
31 9
|
1月前
|
存储 分布式计算 druid
大数据-155 Apache Druid 架构与原理详解 数据存储 索引服务 压缩机制
大数据-155 Apache Druid 架构与原理详解 数据存储 索引服务 压缩机制
56 3
|
1月前
|
存储 SQL 缓存
Apache Doris 3.0 里程碑版本|存算分离架构升级、湖仓一体再进化
从 3.0 系列版本开始,Apache Doris 开始支持存算分离模式,用户可以在集群部署时选择采用存算一体模式或存算分离模式。基于云原生存算分离的架构,用户可以通过多计算集群实现查询负载间的物理隔离以及读写负载隔离,并借助对象存储或 HDFS 等低成本的共享存储系统来大幅降低存储成本。
Apache Doris 3.0 里程碑版本|存算分离架构升级、湖仓一体再进化
|
1月前
|
消息中间件 分布式计算 druid
大数据-154 Apache Druid 架构与原理详解 基础架构、架构演进
大数据-154 Apache Druid 架构与原理详解 基础架构、架构演进
44 2

推荐镜像

更多
下一篇
无影云桌面