ApacheHttpServer与Tomcat实现负载均衡和集群_第1页
ApacheHttpServer与Tomcat实现负载均衡和集群_第2页
ApacheHttpServer与Tomcat实现负载均衡和集群_第3页
ApacheHttpServer与Tomcat实现负载均衡和集群_第4页
ApacheHttpServer与Tomcat实现负载均衡和集群_第5页
已阅读5页,还剩11页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、apache http server与tomcat实现负载均衡和集群apache http server与tomcat实现负载均衡和集群一、分布式实现原理如上图所示,主要通过apache-server作为中转服务器,实现多个tomcat服务器之间的分布式处理,用户直接请求apache-server,然后apache-server会将请求分发到具体的tomcat-server,之后tomcat-server响应客户请求并返回结果到apache-server,最后apache-server返回结果给用户二、负载均衡文件说明:mod_jk.conf主要定义mod_jk模块的位置以及mod_jk模块的

2、连接日志设置,还有定义perties文件的位置。 perties 定义worker的参数,主要是连接tomcat主机的地址和端口信息。如果tomcat与apache不在同一台机器上,或者需要做多台机器上tomcat的负载均衡只需要更改perties文件中的相应定义即可。apache_home为你的安装目录环境说明:主要使用了一个apache server和两个tomcat5.5,在同一台电脑上进行测试。1. 准备软件jdk1.6下载地址:tomcat -6.0.29下载地址:apach

3、e_2.2.4-win32-x86-no_ssl.msi下载地址:/download.cgimod_jk-1.2.31-httpd-2.0.52.so (主要作用是建立apache server与tomcat之间的连接)下载地址:/dist/tomcat/tomcat-connectors/jk/binaries/说明:apache-server安装完成后,可以在浏览器中输入http:/localhost/来测试,如果出现” it works!”则表示安装成功。2. 安装mod_jk连接模块安装好jdk、tom

4、cat、apache后,加入mod_jk连接模块,就是把mod_jk-1.2.31-httpd-2.2.3.so文件拷贝到apache_homemodules下,把jk模块的配置放到单独的文件中来,在apache_homeconf目录新建mod_jk.conf、perties文件。在httpd.conf最后加上:# jk module settingsinclude conf/mod_jk.conf说明:以上表示将mod_jk.conf配置文件包含进来3. 修改mod_jk.conf文件为了保持httpd.conf文件的简洁,把jk

5、模块的配置放到单独的文件中来。在mod_jk.conf文件中添加以下内容:# load mod_jk2 moduleloadmodule jk_module modules/mod_jk-1.2.31-httpd-2.2.3.so# where to find perties(引用workers配置文件)jkworkersfile conf/perties# where to put jk logs(log文件路径)jklogfile logs/mod_jk2.log# set the jk log level debug/error/info(lo

6、g级别)jkloglevel info# select the log format(log格式)jklogstampformat "%a %b %d %h:%m:%s %y "# jkoptions indicate to send ssl key size,jkoptions +forwardkeysize +forwarduricompat -forwarddirectories# jkrequestlogformat set the request formatjkrequestlogformat "%w %v %t"# send jsps fo

7、r context / to worker named loadbalancer(url转发配置,匹配的url才转发到tomcat进行处理)jkmount /*.jsp controller# jkmount /*.* loadbalancer4. 修改perties文件在perties文件中添加以下内容:#server 列表worker.list = controller,tomcat1,tomcat2# tomcat1(ajp13 端口号,在tomcat下server.xml配置,默认8009)worker.tomcat1.port=8009#t

8、omcat的主机地址,如不为本机,请填写ip地址worker.tomcat1.host=localhostworker.tomcat1.type=ajp13#server的加权比重,值越高,分得的请求越多worker.tomcat1.lbfactor = 1# tomcat2worker.tomcat2.port=9009worker.tomcat2.host=localhostworker.tomcat2.type=ajp13worker.tomcat2.lbfactor = 1# controller(负载均衡控制器)worker.controller.type=lb# 指定分担请求的to

9、mcatworker.controller.balanced_workers=tomcat1,tomcat2#worker.controller.sticky_session=true说明:此文件配置了2个tomcat服务器进行负载均衡处理,sticky_session表 述是否将对session id的请求路由回到相同的tomcat worker。如果属性值不为0,它将被设置为jk_true,session将是粘性的,即session id的请求路由回到相同的tomcat worker;当tomcat正使用能够跨越多个tomcat实例持久化session数据的session manager时

10、,它将被设置为jk_false5. 修改tomcat配置文件server.xml更改其中一个的设置打开tomcat2/conf/server.xml文件,修改里面所有的端口设置,将8改为9,如下:6. 编写一个测试页面teat1.jsp建立一个test的web应用,里面新建一个test1.jsp,内容为<% page language="java" contenttype="text/html; charset=utf-8"    pageencoding="

11、utf-8"%><!doctype html public "-/w3c/dtd html 4.01 transitional/en" "/tr/html4/loose.dtd"><html><head><meta http-equiv="content-type" content="text/html; charset=utf-8&qu

12、ot;><title>test1</title></head><body><%    system.out.println("=");%></body></html>7. 启动服务器并进行测试依次启动apache-server、tomcat1、tomcat2,通过 http:/localhost/test/test1.jsp 访问,查看tomcat1的窗口,可以看到打印了一行"=",再刷新一次,tomcat2也打印了

13、一条,再刷新,可以看到请求会被tomcat1,tomcat2轮流处理,实现了负载均衡三、集群(session复制)只配置负载均衡还不行,还要session复制,也就是说其中任何一个tomcat的添加的session,是要同步复制到其它tomcat, 集群内的tomcat都有相同的session1. tomcat配置1.1 修改tomcat1, tomcat2的server.xml文件添加集群内容,tomcat5.5无需添加,只需要去掉注释符,tomcat6.0需要添加,内容如下:tomcat5.5配置<cluster classname="org.apache.cat

14、alina.cluster.tcp.simpletcpcluster"                 managerclassname="org.apache.catalina.cluster.session.deltamanager"             

15、60;   expiresessionsonshutdown="false"                 usedirtyflag="true"                 noti

16、fylistenersonreplication="true">             <membership                 classname="org.apache.catalina.cluster.mcast.mcastservic

17、e"                mcastaddr=""                mcastport="45564"       &

18、#160;        mcastfrequency="500"                mcastdroptime="3000"/>             <rece

19、iver                 classname="org.apache.catalina.cluster.tcp.replicationlistener"                tcplistenaddress="au

20、to"                tcplistenport="4001"                tcpselectortimeout="100"      

21、          tcpthreadcount="6"/>             <sender                classname="org.apa

22、che.catalina.cluster.tcp.replicationtransmitter"                replicationmode="pooled"                acktimeout="1500

23、0"                waitforack="true"/>             <valve classname="org.apache.catalina.cluster.tcp.replicationvalve"&#

24、160;                  filter=".*.gif;.*.js;.*.jpg;.*.png;.*.htm;.*.html;.*.css;.*.txt;"/>                  

25、             <deployer classname="org.apache.catalina.cluster.deploy.farmwardeployer"                      

26、tempdir="/tmp/war-temp/"                      deploydir="/tmp/war-deploy/"                

27、      watchdir="/tmp/war-listen/"                      watchenabled="false"/>          

28、                              <clusterlistener classname="org.apache.catalina.cluster.session.clustersessionlistener"/> 

29、0;      </cluster>tomcat6.0配置<cluster classname="org.apache.catalina.ha.tcp.simpletcpcluster"          channelsendoptions="6">   <!-     

30、60; <manager classname="org.apache.catalina.ha.session.backupmanager"       expiresessionsonshutdown="false"                notifylistenersonreplication

31、="true"                mapsendoptions="6"/>          ->    <manager classname="org.apache.catalina.ha.session.d

32、eltamanager"       expiresessionsonshutdown="false"       notifylistenersonreplication="true"/>       <channel classname="org.apache.catalina.tribes.group

33、.groupchannel">        <membership classname="org.apache.catalina.tribes.membership.mcastservice"              address=""    

34、         port="45564"              frequency="500"              droptime="3000"/>&

35、#160;       <receiver classname="org.apache.catalina.tribes.transport.nio.nioreceiver"          address="auto"          port="5000&q

36、uot;          selectortimeout="100"          maxthreads="6"/>          <sender classname="org.apache.catalina.trib

37、es.transport.replicationtransmitter">           <transport classname="org.apache.catalina.tribes.transport.nio.pooledparallelsender"/>        </sender>   &

38、#160;    <interceptor classname="erceptors.tcpfailuredetector"/>        <interceptor classname="erceptors.messagedispatch15interceptor

39、"/>        <interceptor classname="erceptors.throughputinterceptor"/>    </channel>    <valve classname="org.apache.catalina.ha.tcp.repl

40、icationvalve"       filter=".*.gif;.*.js;.*.jpg;.*.png;.*.htm;.*.html;.*.css;.*.txt;"/>    <deployer classname="org.apache.catalina.ha.deploy.farmwardeployer"        

41、60;  tempdir="/tmp/war-temp/"           deploydir="/tmp/war-deploy/"           watchdir="/tmp/war-listen/"       &#

42、160;   watchenabled="false"/>        <clusterlistener classname="org.apache.catalina.ha.session.clustersessionlistener"/> </cluster>分别添加以上内容后,在tomcat2中,修改tcplistenport="4001" 为40021.2. engin

43、e增加jvmroute属性设置,jvmroute的值来自于perties文件所设置的服务器名称。<engine name="catalina" defaulthost="localhost" jvmroute="tomcat1">#server 列表worker.list = controller,tomcat1,tomcat22. 添加test.jsp页面2.1. test.jsp添加以下内容:<% page contenttype="text/html;

44、0;charset=utf-8"%><% page import="java.util.*"%><html><head><title>cluster app test</title></head><body>server info:<%  out.println(request.getlocaladdr() + " : " +

45、60;request.getlocalport() + "<br>");%><%  out.println("<br> id " + session.getid() + "<br>");  / 如果有新的 session 属性设置  string dataname = request.get

46、parameter("dataname");  if (dataname != null && dataname.length() > 0)      string datavalue = request.getparameter("datavalue");     session.setattribute

47、(dataname, datavalue);    out.print("<b>session 列表</b>");  enumeration e = session.getattributenames();  while (e.hasmoreelements()      string name = (string)

48、0;e.nextelement();     string value = session.getattribute(name).tostring();     out.println(name + " = " + value + "<br>");     system.out.prin

49、tln(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>2.2. 修改web.xml文件,加入<distributable/>节点,如下所示:<?xml version="1.0" encoding="utf-8"?><web-app x

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论