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共享(复制)配置
Tomcat中server.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 中的端口号依次改变