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

本文涉及的产品
应用型负载均衡 ALB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
传统型负载均衡 CLB,每月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)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
8月前
|
设计模式 Java 应用服务中间件
Tomcat 架构原理解析到设计借鉴
Tomcat 架构原理解析到设计借鉴
337 0
|
8月前
|
设计模式 Java 应用服务中间件
Tomcat 架构原理解析到架构设计借鉴
Tomcat 架构原理解析到架构设计借鉴
148 0
|
8月前
|
安全 Java 应用服务中间件
阿里技术官架构使用总结:Spring+MyBatis源码+Tomcat架构解析等
分享Java技术文以及学习经验也有一段时间了,实际上作为程序员,我们都清楚学习的重要性,毕竟时代在发展,互联网之下,稍有一些落后可能就会被淘汰掉,因此我们需要不断去审视自己,通过学习来让自己得到相应的提升。
|
8月前
|
设计模式 安全 Java
【分布式技术专题】「Tomcat技术专题」 探索Tomcat技术架构设计模式的奥秘(Server和Service组件原理分析)
【分布式技术专题】「Tomcat技术专题」 探索Tomcat技术架构设计模式的奥秘(Server和Service组件原理分析)
115 0
|
5月前
|
监控 网络协议 Java
Tomcat源码解析】整体架构组成及核心组件
Tomcat,原名Catalina,是一款优雅轻盈的Web服务器,自4.x版本起扩展了JSP、EL等功能,超越了单纯的Servlet容器范畴。Servlet是Sun公司为Java编程Web应用制定的规范,Tomcat作为Servlet容器,负责构建Request与Response对象,并执行业务逻辑。
Tomcat源码解析】整体架构组成及核心组件
|
3月前
|
前端开发 Java 应用服务中间件
21张图解析Tomcat运行原理与架构全貌
【10月更文挑战第2天】本文通过21张图详细解析了Tomcat的运行原理与架构。Tomcat作为Java Web开发中最流行的Web服务器之一,其架构设计精妙。文章首先介绍了Tomcat的基本组件:Connector(连接器)负责网络通信,Container(容器)处理业务逻辑。连接器内部包括EndPoint、Processor和Adapter等组件,分别处理通信、协议解析和请求封装。容器采用多级结构(Engine、Host、Context、Wrapper),并通过Mapper组件进行请求路由。文章还探讨了Tomcat的生命周期管理、启动与停止机制,并通过源码分析展示了请求处理流程。
|
8月前
|
存储 负载均衡 NoSQL
【分布式技术架构】「Tomcat技术专题」 探索Tomcat集群架构原理和开发分析指南
【分布式技术架构】「Tomcat技术专题」 探索Tomcat集群架构原理和开发分析指南
158 1
|
8月前
|
缓存 负载均衡 应用服务中间件
【分布式技术专题】「分析Web服务器架构」Tomcat服务器的运行架构和LVS负载均衡的运行机制(修订版)
在本章内容中,我们将深入探讨 Tomcat 服务器的运行架构、LVS 负载均衡的运行机制以及 Cache 缓存机制,并提供相应的解决方案和指导。通过理解这些关键概念和机制,您将能够优化您的系统架构,提高性能和可扩展性。
330 4
【分布式技术专题】「分析Web服务器架构」Tomcat服务器的运行架构和LVS负载均衡的运行机制(修订版)
|
8月前
|
前端开发 Java 应用服务中间件
架构篇:Tomcat 高层组件构建一个商业帝国
架构篇:Tomcat 高层组件构建一个商业帝国
342 6
|
8月前
|
XML 应用服务中间件 数据格式
Tomcat - Tomcat套娃式架构与配置文件的对应关系解读
Tomcat - Tomcat套娃式架构与配置文件的对应关系解读
48 1

推荐镜像

更多