tomcat apache 集群

1     Apache2.4版本

1.1        下载Apache

网址:https://www.apachehaus.com/cgi-bin/download.plx

1.2       安装

把下载好的zip文件解压出来,E:\code\Apache24\conf 找到Apache24---->conf下的httpd.conf文件,搜索SRVROOT,将内容替换为你的路径 ,打开E:\code\Apache24\bin目录,运行ApacheMonitor.exe, 桌面的右下角会有一个这样的图标,单击,选择start。打开浏览器,输入网址:http://localhost (不是https)

能访问到则表示安装成功。

1.3             配置集群

1.3.1  打开Apache conf下面的httpd.conf,找到下面这些,去掉文本前的注释符(#)(或者直接复制进去)

LoadModule proxy_modulemodules/mod_proxy.so

LoadModuleproxy_ajp_module modules/mod_proxy_ajp.so

LoadModulerewrite_module modules/mod_rewrite.so

LoadModuleproxy_balancer_module modules/mod_proxy_balancer.so

LoadModuleproxy_connect_module modules/mod_proxy_connect.so

LoadModuleproxy_ftp_module modules/mod_proxy_ftp.so

LoadModuleproxy_http_module modules/mod_proxy_http.so

LoadModuleslotmem_shm_module modules/mod_slotmem_shm.so

LoadModulespeling_module modules/mod_speling.so

LoadModule ssl_module modules/mod_ssl.so

Include conf/extra/httpd-vhosts.conf

1.3.2  找到“DirectoryIndex index.html”字样,在其后追加index.jsp

<IfModuledir_module>

    DirectoryIndex index.html index.jsp

</IfModule>

1.3.3  在文件末尾加反向代理,loadfactor为权限,这里设置都为1,权限一样,http://127.0.0.1:8080loadfactor=1 route=one与Tomcat里面server.xml 配置对应

ProxyRequests Off    # 使用反向代理

<proxy balancer://cluster>

    BalancerMember http://127.0.0.1:8080 loadfactor=1 route=one

    BalancerMember http://127.0.0.1:8090 loadfactor=1 route=two

</proxy> 

1.3.4  找到conf-àextra下面的httpd-vhosts.conf,打开修改 VirtualHost,如下

(请将其他都注释掉)

<VirtualHost *:80>

        ServerAdmin zhaoyi@shuaige.com

        ServerName localhost

        ServerAlias localhost

        ProxyPass / balancer://cluster/ stickysession=jsessionid nofailover=On

        ProxyPassReverse / balancer://cluster/

        ErrorLog "logs/lbtest-error.log"

        CustomLog "logs/lbtest-access.log" common

</VirtualHost>

2      Tomcat配置

如果是同一台服务器,则需要修改tomcat端口号

2.1             分别找到conf下面的server.xml文件,打开,修改端口配置(略)

2.2             添加jvmRoute,分别找到Engine标签,修改如下,jvmRoute的one和two分别与下面的route对应

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

 

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

注:这里的jvmRoute的名称必须与1.3.3中route的名称一致。

2.3             分别在Tomcat下面的webapps下面新建test文件夹,在test下面新建index.jsp,内容如下

<%@page language="java" contentType="text/html; charset=utf-8"

   pageEncoding="utf-8"%>

<!DOCTYPE html PUBLIC"-//W3C//DTD HTML 4.01 Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<metahttp-equiv="Content-Type"content="text/html; charset=utf-8">

<title>Insert title here</title>

</head>

<body>

<%

System.out.println("hello");

%>

it work

</body>

</html>

2.4             开启Tomcat,打开网页,分别输入路径,控制台打印hello,并出现 it work,说明Tomcat配置成功

3      测试

打开浏览器,输入http://localhost/test/index.jsp并且连续刷新,可以看到两个tomcat会依次打印出hello,说明集群配置成功

4      Session共享(复制)

4.1             Session共享(复制)配置

Tomcatserver.xml的配置

server.xml中找到

<ClusterclassName="org.apache.catalina.ha.tcp.SimpleTcpCluster"/> 将注释去掉

4.2             项目配置

在项目的web.xml中加入<distributable/>

5      测试

将index.jsp的内容修改如下:

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

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

<html><head><title>zhaoyishuai 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.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="index.jsp" method="POST">

    名称:<inputtype=text size=20 name="dataName">

    <br>

    值:<inputtype=text size=20 name="dataValue">

    <br>

   <input type=submit>

  </form>

</body>

</html>

然后在test 新建WEB-INF目录,WEB-INF下新建web.xml,内容如下

<web-appxmlns="http://java.sun.com/xml/ns/j2ee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://java.sun.com/xml/ns/j2eehttp://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" version="2.4">

      <display-name>test</display-name>

       <distributable/>

</web-app>

打开浏览器,输入http://localhost/test/index.jsp输入zhaoyi ,shuai点击提交

然后F5多次刷新浏览器,你会发现两个tomcat控制台一次打印出zhaoyi = shuai,server info 中的端口号依次改变

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值