转:https://blog.csdn.net/wangjunjun2008/article/details/38268483

mod-proxy方式实现负载均衡是利用了Apache 2.x版本自带的mod_proxy模块使用代理技术来连接Tomcat;

http_proxy模式基于HTTP协议,要求Tomcat提供HTTP服务,也就是必须启用Tomcat的HTTP Connector;

ajp_proxy模式基于AJP协议,要求Tomcat提供AJP服务,也就是必须启用Tomcat的AJP Connector;

Apache2.2版本之后对mod-proxy模块进行了重写,增强了其功能和稳定性.配置简单,使用广泛.

网上也有大量的相关文章.其具体包括http-proxy,ajp-proxy,ftp-proxy等方式.

采用mod-proxy的连接方式,Apache需要加载以下模块:

LoadModule proxy_module modules/mod_proxy.so

LoadModule proxy_connect_module modules/mod_proxy_connect.so

LoadModule proxy_balancer_module modules/mod_proxy_balancer.so

LoadModule proxy_ajp_module modules/mod_proxy_ajp.so

LoadModule proxy_http_module modules/mod_proxy_http.so

LoadModule manager_module modules/mod_manager.so

下面介绍http-proxy,ajp-proxy两种最常用的方式.

一、准备工作

1) 软件准备

Apache 2.2.25: http://httpd.apache.org/download.cgi

Tomcat 6.0.39: http://tomcat.apache.org/download-60.cgi

2) 软件安装

Windows下安装Apache,并测试服务器正常工作;

Linux下安装 Apache 可参考: http://blog.csdn.net/wangjunjun2008/article/details/38314387;

Tomcat解压缩,分别命名为tomcat1和tomcat2;并启动tomcat测试其正常工作。

二、全局配置

1) 编辑${HTTPD_HOME}/conf/httpd.conf文件,开启以下模块,以便让Apache启动时自动加载:

LoadModule proxy_module modules/mod_proxy.so

LoadModule proxy_connect_module modules/mod_proxy_connect.so

LoadModule proxy_balancer_module modules/mod_proxy_balancer.so

LoadModule proxy_ajp_module modules/mod_proxy_ajp.so

LoadModule proxy_http_module modules/mod_proxy_http.so

LoadModule manager_module modules/mod_manager.so

2) 编辑${HTTPD_HOME}/conf/httpd.conf文件,找到<IfModule dir_module>,在DirectoryIndex index.html 后加上 index.jsp;

这一步只是为了配置完tomcat后能看到小猫首页,可以不做。

3) 分别修改tomcat1和tomcat2的server.xml文件,修改如下标签的端口及,并添加jvmRoute属性:

tomcat1修改后的内容:

<Server port="8010" shutdown="SHUTDOWN">

<Connector port="8080" protocol="HTTP/1.1" ... redirectPort="8443" />

<Connector port="8090" protocol="AJP/1.3" redirectPort="8443" />

<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">

tomcat2修改后的内容:

<Server port="8011" shutdown="SHUTDOWN">

<Connector port="8081" protocol="HTTP/1.1" ... redirectPort="8443" />

<Connector port="8091" protocol="AJP/1.3" redirectPort="8443" />

<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat2">

三、负载均衡配置

对于http_proxy方式,配置如下:

ProxyPass / balancer://httpproxy/

<Proxy balancer://httpproxy/>

  BalancerMember http://127.0.0.1:8080/

  BalancerMember http://127.0.0.1:8081/

</Proxy>

#配置负载均衡管理界面;访问地址为 http://localhost/balancer-manager/

<Location /balancer-manager>

  SetHandler balancer-manager

  order Allow,Deny

  #Deny from All

  Allow from 127.0.0.1

</Location>

【说明】

"httpproxy"是集群名称(可为任意名称)

8080,8081分别对应tomcat的http协议端口;

如此,即可实现apache和tomcat基于http_proxy方式的负载均衡.

访问 http://localhost/balancer-manager 打开如下页面,

对于ajp_proxy方式,配置如下:

ProxyPass / balancer://ajpproxy/

<Proxy balancer://ajpproxy/>

  BalancerMember ajp://127.0.0.1:8090/

  BalancerMember ajp://127.0.0.1:8091/

</Proxy>

【说明】 8090,8091分别对应tomcat的ajp协议端口;

如此,即可实现apache和tomcat基于ajp_proxy方式的负载均衡.

访问 http://localhost/balancer-manager 打开如下页面,

如需具体控制负载均衡中各个节点的负载比例,则将以上配置作如下修改:

ProxyPass / balancer://ajpproxy/

<Proxy balancer://ajpproxy/>

  BalancerMember ajp://127.0.0.1:8090/ loadfactor=1 route=tomcat1

  BalancerMember ajp://127.0.0.1:8091/ loadfactor=2 route=tomcat2

</Proxy>

[说明]

loadfactor 是负载因子(取值范围是1~100),Apache会按照指定数字的比例分发请求(数值越大,处理的请求越多);

比如,两个tomcat的数字都是1,则按1:1的比例分发请求;若是2和1,则按2:1的比例分发请求;

"route=tomcat1" 是负载均衡的节点名称(可为任意名称,但不可重复);

四、添加测试代码

分别在tomcat1和tomcat2添加如下代码:

在${Tomcat_Home}/webapps/下新建test目录,在test目录下新建test.jsp文件,文件内容为:

<%@ page contentType="text/html; charset=GBK" %>
<%@ page import="java.util.*" %>
<html>
<head>
</head>
<body>
<%
out.println("Server IP = " + request.getLocalAddr() + "<br>");
out.println("Server Port = " + request.getLocalPort() + "<br>");
out.println("<br>");
out.println("SessionId = " + session.getId() + "<br>");
out.println("<br>"); String dataName = request.getParameter("dataName");
if (dataName != null && dataName.length() > 0) {
String dataValue = request.getParameter("dataValue");
session.setAttribute(dataName, dataValue);
} out.print("<b>Session 列表</b>");
Enumeration e = session.getAttributeNames();
while (e.hasMoreElements()) {
String name = (String)e.nextElement();
String value = session.getAttribute(name).toString();
out.println( name + " = " + value+"<br>");
System.out.println( name + " = " + value);
}
%> <form action="test.jsp" method="POST">
名称:<input type=text size=20 name="dataName"><br>
值:<input type=text size=20 name="dataValue"><br>
<input type=submit>
</form>
</body>
</html>

五、进行负载均衡测试

启动Apache和tomcat1,tomcat2,访问http://localhost/test/test.jsp,

可以看到包括服务器地址、端口、SessionId等信息在内的页面,如下图:

[说明]

此处的SessionId多了”.tomcat0”,说明处理当前请求的服务器是节点为tomcat0的Tomcat;

如果需要向集群中增加节点,首先需要对新增的Tomcat作类似配置,然后修改${Apache_Home}/conf/httpd.conf 文件,增加BalancerMember,指向新增的tomcat即可。

Apache和Tomcat 配置负载均衡(mod-proxy方式)-无session共享、无粘性session的更多相关文章

  1. Apache和Tomcat 配置负载均衡(mod-proxy方式)-粘性session

    Tomcat集群配置后端Tomcat Server为支持AJP的独立服务,前端Apache配置为粘性会话(sticky-session),Tomcat不配置Cluster配置和Session复制. 配 ...

  2. apache+tomcat配置负载均衡,实现http与websocket接口分压

    一.应用场景 在生产环境中,应用服务器(此文以tomcat为例)不免面临高访问量的压力,相比而言web服务器(此文以apache为例)能够承担更大的并发量.Apache本身带有一些模块,可以完成对应用 ...

  3. 基于Apache和tomcat实现负载均衡

    1.基于Apache和tomcat实现负载均衡 准备三个虚拟机一个安装Apache两个安装Tomcat 关闭防火墙 systemctl stop firewalld Iptabled -F Seten ...

  4. 简单的 Nginx+Tomcat 配置负载均衡集群

    简单 Nginx+Tomcat 配置负载均衡集群 前期准备 解压两个tomcat,修改端口号 server1:8081 server:8082 同时启动 nginx官网下载解压版nginx 创建一个简 ...

  5. Windows下使用Nginx+tomcat配置负载均衡

    Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行.由俄罗斯的程序设计师Igor Sysoev所开发,供俄国大型的入口 ...

  6. nginx和tomcat配置负载均衡和session同步

    一.背景 因业务需求,现需配置多台服务器,实现负载均衡. 二.解决方案 使用 nginx + tomcat,在这一台应用服务器部署一个nginx和两个tomcat.通过nginx修改配置后reload ...

  7. 从零开始学 Java - CentOS 下 Nginx + Tomcat 配置负载均衡

    为什么现在有非常多的聪明人都在致力于互联网? 最近在读埃隆·马斯克传记,他说「我认为现在有非常多的聪明人都在致力于互联网」. 仔细一想,好像真的是这样的. 我问了自己一个问题:如果你不敲代码了,你能做 ...

  8. nginx + tomcat配置负载均衡

    目标:Nginx做为HttpServer,连接多个tomcat应用实例,进行负载均衡. 注:本例程以一台机器为例子,即同一台机器上装一个nginx和2个Tomcat且安装了JDK1.7. 1.安装Ng ...

  9. Nginx+Tomcat 配置负载均衡集群

    一.Hello world 1.前期环境准备 准备两个解压版tomcat,如何同时启动两个tomcat,请看我的另一篇文章<一台机器同时启动多个tomcat>. nginx官网下载解压版n ...

随机推荐

  1. Leetcode之回溯法专题-39. 组合总数(Combination Sum)

    Leetcode之回溯法专题-39. 组合总数(Combination Sum) 给定一个无重复元素的数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使 ...

  2. Python处理NetCDF格式数据为TIFF数据(附脚本代码)

    博客小序:NetCDF格式数据广泛应用于科学数据的存储,最近几日自己利用python处理了一些NetCDF数据,特撰此博文以记之. 参考博客: https://www.cnblogs.com/shou ...

  3. Mac系统中idea配置git总结

    系统配置git相关文章,网上有很多,这里只总结我所遇到的问题 配置git相关信息命令: vim ~/.gitconfig 然后就可以配置相关信息,git配置文件详解请参考以下网址: https://b ...

  4. .NET平台下,钉钉微应用开发之:工作消息通知

    首先看下官方文档,为我们提供了POST请求地址,和几个必传参数的列表以及参数示例,写的都挺详细的. 无奈提供的SDK请求示例是JAVA的,而我用的是.NET的,所以还是摸了一些坑出来,其实也就是不同平 ...

  5. HTML 画布(摘自菜鸟教程)

    颜色.样式和阴影 属性 描述 fillStyle 设置或返回用于填充绘画的颜色.渐变或模式. strokeStyle 设置或返回用于笔触的颜色.渐变或模式. shadowColor 设置或返回用于阴影 ...

  6. 同步机制之一--Synchronized,以及此机制下的锁的本质和种类

    Java中,为了实现同步的操作临界区,线程在执行临界区的代码时,需要获得某个对象的锁.本文介绍获得对象的锁的方法之一----Synchronized关键字. Synchronized关键字的用法 Cl ...

  7. ABC133F - Colorful Tree

    ABC133FColorful Tree 题意 给定一颗边有颜色和权值的树,多次询问,每次询问,首先更改颜色为x的边的权值为y,然后输出u到v的距离. 数据都是1e5量级的. 思路 我自己一开始用树链 ...

  8. 18牛客多校训练第二场 J farm

    题意:一个n×m的农田, 每个小格子都有一种作物, 现在喷t次农药,每次农药覆盖一个矩形, 该矩形里面与农药类型不同的植物都会死掉, 求最后植物的死亡数是多少. 题解:二维树状数组. 每次喷农药的时候 ...

  9. codeforces 284 D. Cow Program(记忆化搜索)

    题目链接:http://codeforces.com/contest/284/problem/D 题意:给出n个数,奇数次操作x,y都加上a[x],偶数次操作y加上a[x],x减去a[x],走出了范围 ...

  10. 堆实战(动态数据流求top k大元素,动态数据流求中位数)

    动态数据集合中求top k大元素 第1大,第2大 ...第k大 k是这群体里最小的 所以要建立个小顶堆 只需要维护一个大小为k的小顶堆 即可 当来的元素(newCome)> 堆顶元素(small ...