原理:tomcat 做个WEB服务器有它的局限性,处理能力低,效率低。承受并发小(1000左右)。但目前有不少网站或者页面是JSP的。并采用了tomcat做为WEB,因此只能在此基础上调优。
目前采取的办法是Apache + Mod_JK + tomcat 来解决一部分请求,用户访问的是apache,但有jsp页面的时候才会去请求tomcat。如果量一大,那么tomcat无法承受,那么只能做tomat集群,Apache + Mod_JK 就是负载均衡器了。
Mod_JK2负载均衡 可以把不同的jsp请求转发到不同的tomcat服务器,还可以侦测服务器存活。如果有条件可以给Mod_JK2做一个HA因为做完集群后压力就在JK上了。
      
简单拓仆图:

准备工作

Tomcat7 http://tomcat.apache.org/download-70.cgi

apache httpd server 2.2: http://httpd.apache.org/download.cgi

apache tomcat connector: http://archive.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/win32/jk-1.2.31/

相关文档:

web server how to:

http://tomcat.apache.org/connectors-doc/webserver_howto/apache.html

安装路径:

httpd:             D:\Server\Apache httpd2_2

tomcat D:\Server\tomcat7-1 tomcat7-2 tomcat7-3

JK  D:\Server\Apache httpd2_2\modules\mod_jk-1.2.31-httpd-2.2.3.so

step 1: 添加并配置JK

D:\Server\Apache httpd2_2\conf\httpd.conf文件最后加上,意思是把这个配置加载进来

Xml代码  
  1. include conf\mod_jk.conf

新建mod_jk.conf文件,内容如下:

Java代码  
  1. LoadModule jk_module modules/mod_jk-1.2.31-httpd-2.2.3.so
  2. JkWorkersFile conf/workers.properties
  3. #指定那些请求交给tomcat处理,"controller"为在workers.propertise里指定的负载分配控制器名
  4. JkMount /*.jsp controller

Step 2: 配置worker

新建并编辑workers.properties文件,内容如下

Java代码  
  1. #server
  2. worker.list = controller
  3. #========tomcat1========
  4. worker.tomcat1.port=11009
  5. worker.tomcat1.host=localhost
  6. worker.tomcat1.type=ajp13
  7. worker.tomcat1.lbfactor = 1
  8. #========tomcat2========
  9. worker.tomcat2.port=12009
  10. worker.tomcat2.host=localhost
  11. worker.tomcat2.type=ajp13
  12. worker.tomcat2.lbfactor = 1
  13. #========tomcat3========
  14. worker.tomcat3.port=13009
  15. worker.tomcat3.host=192.168.0.80 //在我的虚拟机中的,可以算远程的吧
  16. worker.tomcat3.type=ajp13
  17. worker.tomcat3.lbfactor = 1
  18. #========controller,负载均衡控制器========
  19. worker.controller.type=lb
  20. worker.controller.balanced_workers=tomcat1,tomcat2,tomcat3
  21. worker.controller.sticky_session=false
  22. worker.controller.sticky_session_force=1
  23. #worker.controller.sticky_session=1

如果三个tomcat不在同一台机器上,那么下面改端口的事情就可以省很多力气,不过因为要单机做负载均衡,所以要更改三个tomcat的8005,8080的端口,确保都不一样,不然tomcat是没办法同时启动三个的。

测试的时候我三个tomcat都放在本地,因为要同时启动三个tomcat,所以需要更改三个tomcat中的Connector端口号,将三个tomcat的的protocol="HTTP/1.1" 的connector的port改为10080,11080,12080。(原来是8080)

同时讲原来8005的端口分别改成10005,11005,12005(这个是关闭tomcat的端口号)

tomcat7-1

Xml代码  
  1. <Connector port="10080" protocol="HTTP/1.1" connectionTimeout="20000"
  2. redirectPort="8443" />

tomcat7-2

Java代码  
  1. <Connector port="11080" protocol="HTTP/1.1" connectionTimeout="20000"
  2. redirectPort="8443" />

tomcat7-3

Java代码  
  1. <Connector port="12080" protocol="HTTP/1.1" connectionTimeout="20000"
  2. redirectPort="8443" />

除了更改server.xml中 原来的8080的端口(protocol="HTTP/1.1" 的端口号)

还需要配置AJP13的端口号,同时打开默认注释掉的<Cluster>标签,对应的<Engine>的jvmRoute改成workers.property里面对应的名字,配置如下(删除了注释)

tomcat7-1

Xml代码  
  1. <Connector port="11009" protocol="AJP/1.3" redirectPort="8443" />
  2. <Engine name="Catalina" defaultHost="localhost"
  3. jvmRoute="tomcat1">
  4. <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>

tomcat7-2

Java代码  
  1. <Connector port="12009" protocol="AJP/1.3" redirectPort="8443" />
  2. <Engine name="Catalina" defaultHost="localhost"
  3. jvmRoute="tomcat2">
  4. <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>

tomcat7-3

Java代码  
  1. <Connector port="13009" protocol="AJP/1.3" redirectPort="8443" />
  2. <Engine name="Catalina" defaultHost="localhost"
  3. jvmRoute="tomcat3">
  4. <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>

OK,这时候可以成功启动三个tomcat7了,当tomcat7-2启动后,tomcat7-1会打印出replication的信息

类似于

Xml代码  
  1. 2011-9-20 14:12:18 org.apache.catalina.ha.tcp.SimpleTcpCluster memberAdded
  2. 信息: Replication member added:org.apache.catalina.tribes.membership.MemberImpl[tcp://{172, 16, 10, 96}:4001,{172, 16, 10, 96},4001, alive=1000, securePort=-1, UDP Port=-1, id={109 112 -14 -8 -44 98 79 85 -89 -48 -33 -127 -47 -30
  3. 26 -75 }, payload={}, command={}, domain={}, ]
Step3: 建立测试项目
在项目的web.xml中添加<distributable/>
testlb.jsp:
Html代码  
  1. <%@ page contentType="text/html; charset=GBK"%>
  2. <%@ page import="java.util.*"%>
  3. <html>
  4. <head>
  5. <title>Cluster App Test</title>
  6. </head>
  7. <body>
  8. Server Info:
  9. <%
  10. out.println(request.getLocalAddr() + " : " + request.getLocalPort() + "<br>");
  11. %>
  12. <%
  13. out.println("<br> ID " + session.getId() + "<br>");
  14. // 如果有新的 Session 属性设置
  15. String dataName = request.getParameter("dataName");
  16. if (dataName != null && dataName.length() > 0) {
  17. String dataValue = request.getParameter("dataValue");
  18. session.setAttribute(dataName, dataValue);
  19. }
  20. out.println("<b>Session 列表</b><br>");
  21. System.out.println("============================");
  22. Enumeration e = session.getAttributeNames();
  23. while (e.hasMoreElements()) {
  24. String name = (String) e.nextElement();
  25. String value = session.getAttribute(name).toString();
  26. out.println(name + " = " + value + "<br>");
  27. System.out.println(name + " = " + value);
  28. }
  29. %>
  30. <form action="testlb.jsp" method="POST">
  31. 名称:
  32. <input type=text size=20 name="dataName">
  33. <br>
  34. 值:
  35. <input type=text size=20 name="dataValue">
  36. <br>
  37. <input type=submit>
  38. </form>
  39. </body>
  40. </html>
 
多次刷新页面的sessionID看是同一个ID,说明session是复制成功了。那么session中的存储的东西呢,在输入框中分别输入1、1,2、2,3、3后,显示结果如下图: 
 
 

(以下为原文摘抄,我真的比较lazy)

以上的测试说明,集群中的session已经共享,每个集群对于同一访问均有相同的session,而且session中存储的变量也复制了。

节点插拔测试

插拔意思是应该保证当运行的集群中某节点中关闭或者启动时,集群正常工作并且节点能够正常工作。

下面描述测试过程了,贴图太占地方了。

关闭Tomcat2,刷新页面,则不断访问Tocmat1和Tomcat3,再关闭Tomcat1后,则只访问一个Tomcat3,说明节点关闭时运行正常。

如果重启Tomcat2,无论怎么刷新,始终访问Tomcat3,难道Apache不能将请求转发给中途启动的Tomcat2?。。。这时利用另外台机器访问页面,发现Tomcat2正常,然后在刷本地页面,又可以访问Tomcat2了。

从上面可以看出Apache的负载均衡时的算法了,对于每个新来的session,Apache按照节点配置中的lbfactor比重选择访问节点,如果某节点node1不能访问,则寻找下一可访问节点,并且将此node1就在该访问session的访问黑名单中,以后该session的访问直接不考虑node1,即使node1又可以访问了。而新来的session是无黑名单的,如果新的session能够访问到node1了,则会将node1在其他所有session访问的黑名单删除,这样其他session就又能访问node1节点了。以上只是个人经过测试后的猜想。

经过以上测试,说明Tomcat集群和负载均衡已经实现了。

关于集群我还有些疑问,所以又测试了下,直接把结论写出来:

1.集群下的相同的应用可以名称不同(好像没必要啊),只要配置server.xml中host下的context具有相同的path即可。

2. 如果应用名称可以不同,那么应用下内容是否可以不同呢(这里考虑将不同应用通过集群看起来是一个应用,并且共享session),然后集群下不同应用映射为相同的访问path,具有相同的路径则负载,如果某路径只某个应用具有,则一直访问该应用。可现实很骨干啊,答案是否定的,至少我以上的配置不能实现。如果访问只有某应用具有的特别路径,那么只有负载到该应用才可以访问,否则直接路径未找到的错误页面了。

如果您看过网上其他Apache+Tomcat的集群配置,您可能有的疑问?

1.网上大部分的文章配置2个tocmat的集群,有的将workers.properties下的worker.controller.sticky_session=1,
然后tomcat1中的server.xml中的jvmRoute设置为tomcat2,将tomcat2中的jvmRoute设置为tocmat1,当然我这样设置
也成功了,但是如果3个或者更多tocmat呢,怎么设置每个tomcat的jvmRoute,我不会所以才考虑现在的配置

2.server.xml中的Cluster配置问题,网上大部分都是使用BackupManager方式,即Cluster下又粘贴了一堆配置。其实
只要将其中注释掉的<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>去掉注释就完成session的集群
复制了。只是这俩种复制采用的方式不同而已。http://tomcat.apache.org/tomcat-6.0-doc/cluster-howto.html
这页面已经说的挺清楚了,集群的session复制默认是DeltaManager,是all to all的复制,意思是将集群下1个tomcat应用下的session
对所有的集群中的节点进行复制,即使那个节点没有发布应用。显然是不好的方式,但这在小规模的集群下并没神马问题。
而采用BackupManager,就是众多网上配置那样,对于需要复制的节点设置BackupManager自然也没问题,
但是它的性能并没有DeltaManager 好使“ Downside of the BackupManager: not quite as battle tested as the delta manager”。
因此,具体怎么设置就看大家了,通常说如果不是大规模集群,就默认就好了。反正我自己翻译的就是这个意思了,希望没有误导大家。

最后一个比较全的关于session 同步使用jdbc方式的帖子

http://www.datadisk.co.uk/html_docs/java_app/tomcat6/tomcat6_clustering.htm

apache tomcat搭建负载均衡(实现集群中的session同步)的更多相关文章

  1. Apache +Tomcat的负载均衡与集群配置

    实验拓扑图: 一.搭配环境 (1).Tomcat的安装和配置 Tomcat_a的ip:192.168.55.229 Tomcat_b的ip:192.168.55.231 Tomcat的需要安装jdk和 ...

  2. Tomcat负载均衡和集群环境的搭建

    实现此集群的方法参考了网上的很多文章,但由于很多文章都表明是原创的,故无法知道整个操作流程的真正作者是谁.下面就是我用我们真实的项目去实现这个过程.同时修复这过程中一些问题.以下的所有步骤均为亲自测试 ...

  3. Apache+Tomcat部署负载均衡(或集群)

    本来只打算写Tomcat集群部署,简化Apache和Tomcat整合过程的.后来想了想,这样不便于没有用过Apache的朋友来学习本文内容.于是干脆加大篇幅,让对Apache不了解的朋友能对Apach ...

  4. 基于Apache的Tomcat负载均衡和集群(2)

    反向代理负载均衡 (Apache+JK+Tomcat) 使用代理服务器可以将请求转发给内部的Web服务器,让代理服务器将请求均匀地转发给多台内部Web服务器之一上,从而达到负载均衡的目的.这种代理方式 ...

  5. Nginx+Tomcat搭建负载均衡集群

    Nginx ("engine x") 是一个高性能的HTTP和反向代理服务器, 使用 Nginx 可以使得程序在高并发的情况下依旧可以保持良好的性能.使用 Nginx+Tomcat ...

  6. apache的tomcat负载均衡和集群配置 "

    略看了一下,感觉太复杂,要配置的东西太多,因此在这里写出一种更简洁的方法. 要集群tomcat主要是解决SESSION共享的问题,因此我利用memcached来保存session,多台TOMCAT服务 ...

  7. Apache配置反向代理、负载均衡和集群(mod_proxy方式)

    Apache配置负载均衡和集群使用mod_jk的方式比较多,但是mod_jk已经停止更新,并且配置相对复杂.Apache2.2以后,提供了一种原生的方式配置负载均衡和集群,比mod_jk简单很多. 1 ...

  8. 基于nginx的tomcat负载均衡和集群

    要集群tomcat主要是解决SESSION共享的问题,因此我利用memcached来保存session,多台TOMCAT服务器即可共享SESSION了. 你可以自己写tomcat的扩展来保存SESSI ...

  9. 使用 Nginx + Tomcat 搭建负载均衡

    负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽.增加吞吐量.加强网络数据处理能力.提高网络的灵活性和可用性. 负载均衡,英文名称为Load Balance, ...

随机推荐

  1. Android R文件介绍

    R.java 文件中默认有attr.drawable.layout.string等色哥静态内部类,每个静态内部类分别对应着一种资源,如layout静态内部类对应着layout中的接界面文件,其中每个静 ...

  2. centos平台基于snort、barnyard2以及base的IDS(入侵检测系统)的搭建与测试及所遇问题汇总

    centos平台基于snort.barnyard2以及base的IDS(入侵检测系统)的搭建与测试及所遇问题汇总 原创 2016年12月19日 01:20:03 标签: centos / snort  ...

  3. assetBundle 中的prefeb资源图片显示粉色方框

    assetBundle打包的资源是有平台属性的,当移动端iOS或者Android AssetBundle资源 在editor 加载的时候,比如TextMeshPro中的字体就不能正确加载 pc端调试, ...

  4. 图解HTTP第一章

    了解 Web 及网络基础 Web 页面是如何呈现的吗? Web 使用一种名为 HTTP(HyperText Transfer Protocol,超文本传输协议)的协议作为规范,完成从客户端到服务器端等 ...

  5. SAS 输入与输出格式

    SAS 输入与输出格式 一.认识SAS中的数据格式 SAS 中的格式有: 数字型 字符型 日期型 1.其中数字型的格式有一下集中表示方式: 整型数值:321 浮点数值:321.123 带逗号的数值:1 ...

  6. Ubuntu 14.04 LTS 下使用校园网客户端DrclientLinux

    原先博客放弃使用,几篇文章搬运过来 下载客户端并解压 安装开发包 sudo -i dpkg --add-architecture i386 #添加32位的支持 apt-get update apt-g ...

  7. 用scp这个命令来通过ssh传输文件

    小结: 1. upload files 到 ssh 服务器 localhost $ scp localfile root@172.20.34.**:~/remotepath 2. 从 ssh 服务器d ...

  8. 使用docker redis-cluster集群搭建

    参考https://www.cnblogs.com/cxbhakim/p/9151720.html此文 主要搭建过程参考上文,此处讲下主要过程和遇到的坑 首先是镜像的基础搭建,我不知道是否是作者编写时 ...

  9. Python3基础语法你学会了么

      编码 默认:源码文件以UTF-8编码,字符串都是unicode字符串 指定:   标识符 第一个字符:字母表中的字符或下划线 _ 其它部分:由字母.数字.下划线 _ 组成 大小写敏感 python ...

  10. 在Shell脚本中获取指定进程的PID

    注意这条命令用反引号(Tab上面的那个键)括起来,作用类似于${ } processId = ` ps -ef | grep fms.jar | grep -v grep | awk '{print ...