博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
基于apache实现负载均衡调度请求至后端tomcat服务器集群的实现
阅读量:6097 次
发布时间:2019-06-20

本文共 2626 字,大约阅读时间需要 8 分钟。

一、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 ;##将来自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的不同域名时,能反向解析处理报文    
require all granted ####授予反向代理的内容访问权限
proxypass / balancer://tomcats/ ###把客户端请求的URL路径代理至上面定义好的负载均衡组tomcats对应路径上 proxypassreverse / balancer://tomcats/ ####经过调度器LB反解处理的URL请求也代理至后端集群的对应路径
require all granted ###定义访问权限
###定义apache负载均衡的状态统计页 sethandler balancer-manager proxypass ! require all granted

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端口,只需修改对应端口与协议即可

转载地址:http://qfbza.baihongyu.com/

你可能感兴趣的文章
orcale安装(grid 及变量的编写 )
查看>>
Java日志系统研究
查看>>
ASO优化
查看>>
MySql 数据库嵌入查询式 C++
查看>>
PHP用正则表达式.XML转数组.
查看>>
如何在mac系统下将mysql加入环境变量
查看>>
设计模式六大原则(2):里氏替换原则
查看>>
MyEclipse for Linux 的版本
查看>>
了解Jalangi2
查看>>
Google I/O 2016笔记之图像压缩
查看>>
mongodb的命令大全
查看>>
如何用js判断一个复选框是否被选中
查看>>
苹果首席设计师谈iOS7扁平风格,对设计的理解非常的有高度
查看>>
分享reset.css
查看>>
Go 1.1 is released! [转]
查看>>
密码技术十 证书
查看>>
Android Dependencies
查看>>
IE9关联数组导致内存泄漏测试报告
查看>>
开始学习汇编语言
查看>>
14.3-全栈Java笔记:JPanel原来是这样用的
查看>>