基于apache实现负载均衡调度请求至后端tomcat服务器集群的实现

本文涉及的产品
网络型负载均衡 NLB,每月750个小时 15LCU
传统型负载均衡 CLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
简介: 基于apache实现负载均衡调度请求至后端tomcat服务器集群的实现

一、LNMT实现
1、LNMT基本流程如下:
clinet===>http协议====>nginx====>reverse_proxy===>tomcat(connector组件)
客户端通过http协议将请求发送给nginx前端服务器,nginx将请求报文通过反向代理发送给tomcat,其中tomcat通过connector连接器接入请求并响应
2、nginx反向代理的配置:
编辑/etc/nginx/nginx.conf文件,添加新配置:
location / {

    #root   /usr/share/nginx/html;
   proxy_pass http://localhost:8080/ ;
    index  index.html index.htm;
}

proxy_pass http://localhost:8080/ ;##将来自nginx的请求反向代理至后端tomcat服务器,这需要在这里定义这一段即可。使用curl命令测试请求nginx监听的80端口会被反向代理至tomcat监听的8080端口
1
3、使用apache做负载衡调度器反向代理请求至后端tomcat:
因为tomcat支持的有基于AJP协议的连接器,而AJP连接器是一种二进制的协议 ,因此比http更好的性能。并且使用AJP连接器进行反向代理请求时,客户端主机没法通过http协议绕过前端的反向代理服务器,具有更好的操作可行性。所以,在使用前端服务器反向代理请求至tomcat这种模型架构中,一般作为tomcat的前端反向代理服务器大多为apache,然后再基于nginx做负载均衡调度请求给apache:
client===>nginx(负载均衡调度器)====>apache反向代理服务器===>tomcat服务器(基于AJP协议)

三、搭建一个以apache做负载均衡与反向代理服务器的简单模型:
1、实验服务器环境:
有三台阿里云服务器:A 172.18.224.100(使用apache提供反向代理与负载均衡效果)、B 172.18.224.101(tomcat服务器B) 、C、172.18.224.102(tomcat服务器C)
2、tomcatB、tomcatC提供测试页面:
a、关闭防火墙,安装JDK与tomcat(此处略过)
b、TomcatB服务器在tomcat/webapps/创建一个名为myapp的应用并提供测试页index.jsp:
cd /usr/local/tomcat/webapps/myapp
mkdir lib classes WEB-INF META-INF lib
vim index.jsp
index.jsp内容如下:
2
进行页面测试:
3

c、TomcatC服务器在tomcat/webapps/创建一个名为myapp的应用并提供测试页index.jsp:
cd /usr/local/tomcat/webapps/myapp
mkdir lib classes WEB-INF META-INF lib
vim index.jsp
index.jsp内容如下:

4
进行页面测试:
5

3、在服务器A上配置负载均衡apache反向代理自tomcatB、tomcatC:
1

###定义负载均衡服务器tomcats并反向代理至tomcatB、tomcatC

    balancerMember http://172.18.224.101:8080 loadfactor=1   
    balancerMember http://172.18.224.102:8080 loadfactor=1 ###定义负载均衡集群101、102,loadfactor =1 定义权重为1,假设102的loadfactor=2可以简单理解为每3次请求会有2次请求被调度到102这台服务器,有1次被调度到101服务器
    proxyset lbmethod=byrequests  ###设置负载均衡为轮询调度

###定义虚拟主机反向代理请求

    servername      lb    ###服务名称
    proxyvia        on      ###表明在后端tomcat服务器中http报文中的请求头via,在后端tomcat服务器的日志能获取到真正客户端请求ip与调度器的ip地址
    proxyrequests   off #####取消正向代理
    proxypreservehost       on  ###当客户端请求了LB的不同域名时,能反向解析处理报文
    <proxy  *>
            require all granted ####授予反向代理的内容访问权限
    </proxy>
    proxypass       /       balancer://tomcats/  ###把客户端请求的URL路径代理至上面定义好的负载均衡组tomcats对应路径上
    proxypassreverse /      balancer://tomcats/ ####经过调度器LB反解处理的URL请求也代理至后端集群的对应路径
    <location />
            require all granted  ###定义访问权限
    </location>

    <location /balancer-manager>  ###定义apache负载均衡的状态统计页
            sethandler balancer-manager
            proxypass !
            require all granted
    </location>


4、进行测试
浏览器访问负载均衡器A的/myapp/并进行多次刷新,发现成功构建了基于轮训的负载均衡到tomcat集群上
6
7

5、apache自带的负载均衡状态统计页面:
访问负载均衡器A的/balancer-manage页面8
页面中可以配置调度算法、流量统计、集群服务器上下线等功能

6、apache使用ajp协议反代请求至后端tomcat集群:
在实际生产环境中,一般是这种模型架构:
client====>负载均衡调度器(nginx/haproxy)===>apache(ajp协议反向代理)====>tomcat集群
基于ajp协议的反代配置如下:
2
tomcat的ajp连接器默认监听在8009端口,只需修改对应端口与协议即可

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
目录
相关文章
|
10月前
|
弹性计算 监控 负载均衡
|
2月前
|
监控 Java 应用服务中间件
低并发编程|如何用720个请求让后端服务器瘫痪
本次故障因应用启动时未有效校验核心依赖模块初始化异常,导致后续请求处理中抛出无法捕获的错误,引发线程阻塞,最终耗尽HSF线程池,服务不可用。排查发现类初始化失败且异常未被正确处理,结合线程无限等待问题,确认为依赖初始化异常与流处理中断所致。修复措施包括加强启动校验、捕获Throwable及设置合理超时。总结指出,系统稳定性需从细节入手,防微杜渐,避免连锁故障。
低并发编程|如何用720个请求让后端服务器瘫痪
|
4月前
|
负载均衡 前端开发 应用服务中间件
Tomcat的负载均衡和动静分离(与nginx联动)
总的来说,负载均衡和动静分离是提高Web应用性能的两个重要手段。通过合理的配置和使用,我们可以让Web应用更好地服务于用户。
144 21
|
4月前
|
负载均衡 Java 应用服务中间件
Tomcat与Nginx的负载均衡与动静分离技巧
总的来说,Tomcat和Nginx各有各的优点,在负载均衡和动静分离这两方面它们都有很好的应用。灵活使用这两个工具能够让Web应用具有更好的扩展性和用户体验。
118 14
|
4月前
|
负载均衡 前端开发 JavaScript
LVS-DR模式、keepalived、Nginx与Tomcat合作,打造动静分离,高效负载均衡与高可用性
为了采用这样的架构,你需要对LVS-DR、Keepalived、Nginx与Tomcat有一定的理解和掌握,同时也需要投入一些时间去研究和配置,但是一旦你把它运行起来,你将会发现,这一切都是值得的。
156 11
|
9月前
|
运维 监控 负载均衡
slb后端服务器故障
slb后端服务器故障
174 13
|
9月前
|
缓存 负载均衡 算法
深入理解后端服务的负载均衡技术
在现代网络服务架构中,高效的负载均衡策略对于保证应用性能和可靠性至关重要。本文将深入探讨后端服务中的负载均衡技术,包括其重要性、常见算法以及如何实现高效均衡。通过分析不同的负载均衡方法,我们旨在为开发者提供实用的指导,帮助他们优化自己的系统架构。
|
10月前
|
监控 负载均衡 算法
slb管理后端服务器
【10月更文挑战第18天】
109 5
|
11月前
|
负载均衡 应用服务中间件 Apache
Tomcat负载均衡原理详解及配置Apache2.2.22+Tomcat7
Tomcat负载均衡原理详解及配置Apache2.2.22+Tomcat7
173 3
|
11月前
|
前端开发 Java
学习SpringMVC,建立连接,请求,响应 SpringBoot初学,如何前后端交互(后端版)?最简单的能通过网址访问的后端服务器代码举例
文章介绍了如何使用SpringBoot创建简单的后端服务器来处理HTTP请求,包括建立连接、编写Controller处理请求,并返回响应给前端或网址。
256 0
学习SpringMVC,建立连接,请求,响应 SpringBoot初学,如何前后端交互(后端版)?最简单的能通过网址访问的后端服务器代码举例