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

简介: 快速学习常见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 架构通过此架构比较稳定

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

相关实践学习
部署高可用架构
本场景主要介绍如何使用云服务器ECS、负载均衡SLB、云数据库RDS和数据传输服务产品来部署多可用区高可用架构。
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
15天前
|
机器学习/深度学习 API 语音技术
|
1天前
|
JSON API 数据库
后端架构设计与优化:打造高性能应用后端
后端架构设计与优化:打造高性能应用后端
10 2
|
10天前
|
人工智能 Serverless 数据处理
利用阿里云函数计算实现 Serverless 架构的应用
阿里云函数计算是事件驱动的Serverless服务,免服务器管理,自动扩展资源。它降低了基础设施成本,提高了开发效率,支持Web应用、数据处理、AI和定时任务等多种场景。通过实例展示了如何用Python实现图片压缩应用,通过OSS触发函数自动执行。阿里云函数计算在云计算时代助力企业实现快速迭代和高效运营。
46 0
|
13天前
|
运维 监控 自动驾驶
构建可扩展的应用程序:Apollo与微服务架构的完美结合
构建可扩展的应用程序:Apollo与微服务架构的完美结合
32 10
|
15天前
|
机器学习/深度学习 PyTorch API
|
15天前
|
机器学习/深度学习 语音技术 算法框架/工具
|
16天前
|
运维 Cloud Native 持续交付
构建未来:云原生架构在现代企业中的应用与挑战
【4月更文挑战第10天】 随着数字化转型的不断深入,企业对信息技术基础设施的要求日益提高。云原生架构作为一种新兴的设计理念和技术集合,以其灵活性、可扩展性和容错性,正在成为推动企业技术革新的关键力量。本文将探讨云原生技术的核心组件、实施策略以及面临的主要挑战,并分析如何通过采纳云原生架构来优化业务流程和提升服务效率。
|
Java 应用服务中间件 Apache
Apache 与tomcat实现分布式应用部署
一:原理 tomcat是一个web应用服务器,能够解析静态文件和动态文件(如:html、jsp、servlet等);apache是一个web server,能够解析静态文件。Tomcat作为一个独立的web服务器是可以使用的,但是它对静态文件的解析能力不如apache,所以就产生现在的web应用的分布式部署,apache+tomcat。 两者之间的通信通过workers配置(由tomc
2126 0
|
1月前
|
消息中间件 API Apache
官宣|阿里巴巴捐赠的 Flink CDC 项目正式加入 Apache 基金会
本文整理自阿里云开源大数据平台徐榜江 (雪尽),关于阿里巴巴捐赠的 Flink CDC 项目正式加入 Apache 基金会。
1415 1
官宣|阿里巴巴捐赠的 Flink CDC 项目正式加入 Apache 基金会
|
1月前
|
SQL Java API
官宣|Apache Flink 1.19 发布公告
Apache Flink PMC(项目管理委员)很高兴地宣布发布 Apache Flink 1.19.0。
1355 1
官宣|Apache Flink 1.19 发布公告

推荐镜像

更多