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

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
简介: 一、常用的LAMT应用架构二、tomcat 的安装配置以及jk模块的配置三、LAMT负载均衡架构的实现四、具体使用流程

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

 

目录:

一、常用的LAMT应用架构

二、tomcat 的安装配置以及jk模块的配置
三、LAMT负载均衡架构的实现

四、具体使用流程

 

 

一、常用的LAMT应用架构

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

image.png

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

Apache

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

 

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

 

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

tomcat处理动态请求更为专业

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

jk模块实现ApacheTomcat交互,连接作用

 

为什么整合tomcatapache

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
:放一些可执行的脚本文件,比如我们要启动和关闭tomca的可执行文件也在里面
     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类型有两种,ajp12ajp13,实现通信

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.log
JkLogLevelinfo
JkLogStampformat"[%a%b%d%H:%M:%S%Y]"

uriworkermap.properties 文件

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

 

#.jsp文件分配给控制器

/*.jsp=controller

#所有以*.jsp文件全部交给tomcat12

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

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


!/*.jpg=controller
!/*.gif=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 32016 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

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

 

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

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

相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
8天前
|
监控 网络协议 Java
Tomcat源码解析】整体架构组成及核心组件
Tomcat,原名Catalina,是一款优雅轻盈的Web服务器,自4.x版本起扩展了JSP、EL等功能,超越了单纯的Servlet容器范畴。Servlet是Sun公司为Java编程Web应用制定的规范,Tomcat作为Servlet容器,负责构建Request与Response对象,并执行业务逻辑。
Tomcat源码解析】整体架构组成及核心组件
|
9天前
|
Prometheus 监控 Kubernetes
Prometheus 在微服务架构中的应用
【8月更文第29天】随着微服务架构的普及,监控和跟踪各个服务的状态变得尤为重要。Prometheus 是一个开源的监控系统和时间序列数据库,非常适合用于微服务架构中的监控。本文将详细介绍 Prometheus 如何支持微服务架构下的监控需求,包括服务发现、服务间的监控指标收集以及如何配置 Prometheus 来适应这些需求。
32 0
|
2天前
|
传感器 Cloud Native 物联网
Micronaut在物联网中的应用探索:轻盈架构赋能万物互联新时代
【9月更文挑战第6天】Micronaut是一个现代、轻量级的Java框架,以其高效、易用及对云原生环境的支持,在物联网开发中展现出独特优势。它通过AOT编译技术优化应用,减少内存消耗,适合资源受限的设备。Micronaut支持反应式编程和HTTP/2,提升并发处理能力和网络传输效率。本文通过一个温度传感器数据收集服务的例子,展示了如何利用Micronaut简化物联网应用开发,使其成为该领域的理想选择。
12 3
|
11天前
|
Kubernetes Cloud Native 开发者
云原生技术在现代IT架构中的应用与挑战
【8月更文挑战第27天】 随着云计算的飞速发展,云原生技术已经成为推动企业数字化转型的重要力量。本文将深入探讨云原生技术的核心概念、优势以及在实际应用中遇到的挑战,并通过具体代码示例展示如何利用云原生技术优化IT架构。
|
7天前
|
存储 前端开发 数据库
神秘编程世界惊现强大架构!Web2py 的 MVC 究竟隐藏着怎样的神奇魔力?带你探索实际应用之谜!
【8月更文挑战第31天】在现代 Web 开发中,MVC(Model-View-Controller)架构被广泛应用,将应用程序分为模型、视图和控制器三个部分,有助于提高代码的可维护性、可扩展性和可测试性。Web2py 是一个采用 MVC 架构的 Python Web 框架,其中模型处理数据和业务逻辑,视图负责呈现数据给用户,控制器则协调模型和视图之间的交互。
14 0
|
8天前
|
运维 应用服务中间件 网络安全
自动化运维的新篇章:Ansible在现代IT架构中的应用与实践
【8月更文挑战第30天】随着信息技术的飞速发展,企业对运维效率和可靠性的要求日益增高。传统的手动运维方式已难以应对复杂多变的IT环境,自动化运维因此成为行业新宠。本文将深入探讨Ansible这一流行的自动化工具,如何通过其简洁的配置管理和强大的多节点部署能力,助力现代IT架构实现高效、可靠的运维管理。我们将从Ansible的核心概念入手,逐步解析其在配置管理、任务执行、应用部署等方面的实战应用,并结合代码示例,展示如何利用Ansible简化日常运维工作,提升运维质量和效率。无论你是运维新手还是资深专家,这篇文章都将为你提供宝贵的洞见和实操技巧。
|
12天前
|
存储 消息中间件 Java
Apache Flink 实践问题之原生TM UI日志问题如何解决
Apache Flink 实践问题之原生TM UI日志问题如何解决
27 1
|
10天前
|
消息中间件 监控 数据挖掘
基于RabbitMQ与Apache Flink构建实时分析系统
【8月更文第28天】本文将介绍如何利用RabbitMQ作为数据源,结合Apache Flink进行实时数据分析。我们将构建一个简单的实时分析系统,该系统能够接收来自不同来源的数据,对数据进行实时处理,并将结果输出到另一个队列或存储系统中。
52 2
|
12天前
|
消息中间件 分布式计算 Hadoop
Apache Flink 实践问题之Flume与Hadoop之间的物理墙问题如何解决
Apache Flink 实践问题之Flume与Hadoop之间的物理墙问题如何解决
27 3
|
12天前
|
消息中间件 运维 Kafka
Apache Flink 实践问题之达到网卡的最大速度如何解决
Apache Flink 实践问题之达到网卡的最大速度如何解决
32 2

推荐镜像

更多
下一篇
DDNS