tomcat集群配置

目前javaweb开发的项目越来越多,但如果想要网站支持庞大的访问量,就得需要多台服务器分担访问量,这就涉及到了集群的概念。

tomcat(以6.0版本为例)集群配置如下:

1.Apache

 Apache是http服务器,我们利用它实现对tomcat的负载均衡。apache下载地址为:http://archive.apache.org/dist/httpd/。安装完成后,访问http://localhost出现如下界面表示apache安装成功:

2.tomcat

tomcat就不用多介绍了,但需要注意的是一个集群下不能即有tomcat6也有tomcat7,否则虽然能负载均衡,但session无法进行复制。

 

tomcat和apache服务器连接方式有三种:mod_jk、http_proxy和ajp_proxy。

本次实例以mod_jk为例进行配置,下载地址为:http://mirror.bjtu.edu.cn/apache/tomcat/tomcat-connectors/jk/binaries/windows/

3.配置过程

1)修改apache配置

      修改apache安装目录下的conf/httpd.conf文件,在文件最后一行添加如下内容:

       include "D:\Program Files (x86)\Apache Software Foundation\Apache2.2\conf\mod_jk.conf"

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

       LoadModule jk_module modules/mod_jk-1.2.31-httpd-2.2.3.so

       JkWorkersFile conf/workers.properties

       #指定那些请求交给tomcat处理,"controller"为在workers.propertise里指定的负载分配控制器名

      JkMount /*.* controller

     将下载的JK插件mod_jk.so复制到Apache安装目录的modules目录下。

     

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

#server

worker.list = controller

#========tomcat1========

worker.tomcat1.port=8082

worker.tomcat1.host=localhost

worker.tomcat1.type=ajp13

worker.tomcat1.lbfactor = 1

#========tomcat2========

worker.tomcat2.port=8083

worker.tomcat2.host=localhost

worker.tomcat2.type=ajp13

worker.tomcat2.lbfactor = 1

 

#========controller,负载均衡控制器========

worker.controller.type=lb

worker.controller.balanced_workers=tomcat1,tomcat2

worker.controller.sticky_session=false

worker.controller.sticky_session_force=1

#worker.controller.sticky_session=1

配置Tomcat

配置2个Tomcat服务器,将Tomcat解压后复制2份,我将每个文件夹分别命名为Tomcat1和Tomcat2,修改每一份的server.xml配置,修改部分如下图:

AJP13的connector的poat和jvmRoute名称和workers.properties中配置对应。

还需要保证本地2个本地Tomcat配置serverportconnectorhttp1.1port都不相同。

 

测试

建立测试项目

建立test项目,需要在项目的web.xml中添加<distributable/>

建立test2.jsp,内容如下(网上都用这个测试,我就省的麻烦了):

<%@ page contentType="text/html; charset=GBK" %>

<%@ page import="java.util.*" %>

<html><head><title>Cluster App Test</title></head>

<body>

Server Info:

<%

out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");%>

<%

  out.println("<br> ID " + session.getId()+"<br>");

  // 如果有新的 Session 属性设置

  String dataName = request.getParameter("dataName");

  if (dataName != null && dataName.length() > 0) {

     String dataValue = request.getParameter("dataValue");

     session.setAttribute(dataName, dataValue);

  }

  out.println("<b>Session 列表</b><br>");

  System.out.println("============================");

  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="test2.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>

上面的测试页面就不解释了,很好理解。

 

 

      

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值