由于目前很多apache+tomcat集群都是在apache2.2上配置的,Apache2.4的教程几乎没有,这里写一篇记录下来。

环境:apache2.4.12(Apache Haus编译版本)、tomcat8.0.15、1.2.40版本的mod_jk.so、jdk-7u71、操作系统winxp

关于这几个软件的下载安装,这里就不多说,注意apache2.4必须安装在根目录,mod_jk必须下载Apache对应的版本

软件

笔者环境

三台xp虚拟机

1.Apache服务器,IP:192.168.116.132

2.tomcat服务器一,IP:192.168.116.133

3.tomcat服务器二,IP:192.168.116.134

一、Apache服务器配置

笔者将Apache安装在了C盘根目录下

1.将mod_jk.so复制到Apache的modules目录(笔者为C:\Apache24\modules)

2.在Apache的conf目录(笔者为C:\Apache24\conf)找到httpd.conf,在文件最后添加

include "C:\Apache24\conf\mod_jk.conf"

3.在Apache的conf目录(笔者为C:\Apache24\conf)新建文件mod_jk.conf,添加如下内容

LoadModule jk_module modules/mod_jk.so
JkWorkersFile conf/workers.properties
JkLogFile logs/mod_jk.log
JkLogLevel debug
JkMount /*.jsp controller

这里强烈建议把JkLogLevel debug加上,否则出错找不到原因

4.在Apache的conf目录(笔者为C:\Apache24\conf)新建文件workers.properties,添加如下内容

#server
worker.list = controller
#========tomcat1========
worker.tomcat1.port=
worker.tomcat1.host=192.168.116.133
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor= #========tomcat2========
worker.tomcat2.port=
worker.tomcat2.host=192.168.116.134
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor= #========controller,负载均衡控制器========
worker.controller.type=lb
worker.controller.retries=
worker.controller.balance_workers=tomcat1,tomcat2
worker.controller.sticky_session=false
worker.controller.sticky_session_force=false

二、tomcat服务器配置

打开tomcat的conf目录下的server.xml,找到AJP/1.3连接器,端口与workers.properties的worker.[名称].port设置成一致,默认是8009,在Engine里面添加jvmRoute,名称与worker.后面的名称一致,最后去掉<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>两边的注释,两个服务器配置文件大致一样,仅jvmRoute设置不一样。

tomcat服务器一:

 <!-- Define an AJP 1.3 Connector on port 8009 -->
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443"/> <!-- An Engine represents the entry point (within Catalina) that processes
every request. The Engine implementation for Tomcat stand alone
analyzes the HTTP headers included with the request, and passes them
on to the appropriate Host (virtual host).
Documentation at /docs/config/engine.html --> <!-- You should set jvmRoute to support load-balancing via AJP ie :
<Engine name="Catalina" defaultHost="localhost" jvmRoute="jvm1">
-->
<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1"> <!--For clustering, please take a look at documentation at:
/docs/cluster-howto.html (simple how to)
/docs/config/cluster.html (reference documentation) -->
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
<!--
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
--> <!-- Use the LockOutRealm to prevent attempts to guess user passwords
via a brute-force attack -->
<Realm className="org.apache.catalina.realm.LockOutRealm">
<!-- This Realm uses the UserDatabase configured in the global JNDI
resources under the key "UserDatabase". Any edits
that are performed against this UserDatabase are immediately
available for use by the Realm. -->
<Realm className="org.apache.catalina.realm.UserDatabaseRealm"
resourceName="UserDatabase"/>
</Realm> <Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true"> <!-- SingleSignOn valve, share authentication between web applications
Documentation at: /docs/config/valve.html -->
<!--
<Valve className="org.apache.catalina.authenticator.SingleSignOn" />
--> <!-- Access log processes all example.
Documentation at: /docs/config/valve.html
Note: The pattern used is equivalent to using pattern="common" -->
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log" suffix=".txt"
pattern="%h %l %u %t &quot;%r&quot; %s %b" /> </Host>
</Engine>

tomcat服务器二:

 <!-- Define an AJP 1.3 Connector on port 8009 -->
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443"/> <!-- An Engine represents the entry point (within Catalina) that processes
every request. The Engine implementation for Tomcat stand alone
analyzes the HTTP headers included with the request, and passes them
on to the appropriate Host (virtual host).
Documentation at /docs/config/engine.html --> <!-- You should set jvmRoute to support load-balancing via AJP ie :
<Engine name="Catalina" defaultHost="localhost" jvmRoute="jvm1">
-->
<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat2"> <!--For clustering, please take a look at documentation at:
/docs/cluster-howto.html (simple how to)
/docs/config/cluster.html (reference documentation) -->
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
<!--
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
--> <!-- Use the LockOutRealm to prevent attempts to guess user passwords
via a brute-force attack -->
<Realm className="org.apache.catalina.realm.LockOutRealm">
<!-- This Realm uses the UserDatabase configured in the global JNDI
resources under the key "UserDatabase". Any edits
that are performed against this UserDatabase are immediately
available for use by the Realm. -->
<Realm className="org.apache.catalina.realm.UserDatabaseRealm"
resourceName="UserDatabase"/>
</Realm> <Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true"> <!-- SingleSignOn valve, share authentication between web applications
Documentation at: /docs/config/valve.html -->
<!--
<Valve className="org.apache.catalina.authenticator.SingleSignOn" />
--> <!-- Access log processes all example.
Documentation at: /docs/config/valve.html
Note: The pattern used is equivalent to using pattern="common" -->
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log" suffix=".txt"
pattern="%h %l %u %t &quot;%r&quot; %s %b" /> </Host>
</Engine>

编写文件部署到tomcat,笔者也懒得写,大家都抄来抄去的

index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ page import="java.util.Enumeration"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<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="index.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>

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>testc</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
<distributable/>
</web-app>

需要注意的是web.xml里面的必须要加上<distributable/>,然后部署到两个tomcat服务器中

三、启动测试运行

先启动apache服务器,然后启动2个tomcat服务器

浏览器打开http://192.168.116.132/test/index.jsp

然而奇迹并没有出现,而是出现了404页面,提示文字为

Not Found

The requested URL /test/index.jsp was not found on this server.

接下来我们要看日志文件,看看问题出在哪里

找到jk的日志文件(C:\Apache24\logs\mod_jk.log)

直接看最后几行

[Sat May  ::38.718 ] [:] [debug] extension_fix_activation::jk_uri_worker_map.c (): Checking extension for worker controller of type lb ()
[Sat May ::38.718 ] [:] [debug] uri_worker_map_dump::jk_uri_worker_map.c (): uri map dump after extension stripping: id=, index= file='(null)' reject_unsafe= reload= modified= checked=
[Sat May ::38.718 ] [:] [debug] uri_worker_map_dump::jk_uri_worker_map.c (): generation : size= nosize= capacity=
[Sat May ::38.718 ] [:] [debug] uri_worker_map_dump::jk_uri_worker_map.c (): generation : size= nosize= capacity=
[Sat May ::38.718 ] [:] [debug] uri_worker_map_dump::jk_uri_worker_map.c (): NEXT () map #: uri=/*.jsp worker=controller context=/*.jsp source=JkMount type=Wildchar len=6
[Sat May 16 20:12:38.718 2015] [2176:1048] [debug] uri_worker_map_switch::jk_uri_worker_map.c (600): Switching uri worker map from index 0 to index 1
[Sat May 16 20:12:38.718 2015] [2176:1048] [debug] jk_shm_open::jk_shm.c (168): Shared memory is already opened
[Sat May 16 20:12:38.718 2015] [2176:1048] [debug] jk_shm_attach::jk_shm.c (337): Attached shared memory memory [1] size=2560 free=0 addr=0x32bb30
[Sat May 16 20:12:38.718 2015] [2176:1048] [debug] jk_child_init::mod_jk.c (3266): Initialized mod_jk/1.2.40
[Sat May 16 20:12:38.750 2015] [2176:3584] [debug] jk_translate::mod_jk.c (3623): missing uri map for localhost:/test/index.jsp
[Sat May 16 20:12:38.750 2015] [2176:3584] [debug] jk_map_to_storage::mod_jk.c (3791): missing uri map for localhost:/test/index.jsp

通过搜索关键字missing uri map for localhost:/找到一篇文章

http://blog.csdn.net/bluecy/article/details/5897103

具体意思是在<VirtualHost>标签中添加JkMountCopy On,然而作者并没有说是哪个文件......

笔者也上谷歌搜了,也是添加这个,但就是找不到

笔者最后还是找到了这个文件,文件在C:\Apache24\conf\extra的httpd-vhosts.conf,为什么大家都不说这个啊。。。。。。笔者很是郁闷

默认情况下已经配置了一个虚拟主机

<VirtualHost _default_:80>
DocumentRoot "${SRVROOT}/htdocs"
#ServerName www.example.com:80
</VirtualHost>

然后在中间添加JkMountCopy On就行了(如果有多个要配置多个)

<VirtualHost _default_:80>
DocumentRoot "${SRVROOT}/htdocs"
#ServerName www.example.com:80
JkMountCopy On
</VirtualHost>

如果读者用的2.2版本,应该不会遇到要配置虚拟主机参数的问题。

保存之后重启apache服务器,然后在浏览器重新打开

http://192.168.116.132/test/index.jsp

F5刷新

可以看到sessionid并没有发生变化

在名称和值中分别输入1、1、2、2、3、3、4、4,可以看到如下结果

上面的测试说明,session已经能够共享,并且session里面存储的变量也能够在集群中复制。

apache2.4+tomcat8+jk1.2.40集群配置的更多相关文章

  1. Apache 2.4.12 64位+Tomcat-8.0.32-windows-x64负载集群方案

    上次搞了Apache 2.2的集群方案,但是现在自己的机器和客户的服务器一般都是64位的,而且tomcat已经到8了.重新做Apache 2.4.12 64位+Tomcat-8.0.32-window ...

  2. apache2.2.25+tomcat7.0.47集群方案

    因为公司项目在线人数的增加,随着现在硬件成本越来越低,大多数的生产环境内存大多都已经达到 16G,尤其最新的阿里云,客户的机器都是配置超高的java主机,但是Java的运行环境,内存使用有限 ,这样就 ...

  3. Linux+Apache+Tomcat集群配置

    参考: http://blog.csdn.net/bluishglc/article/details/6867358# http://andashu.blog.51cto.com/8673810/13 ...

  4. (转)Apache+Tomcat集群配置

    本文Apache+Tomcat集群配置 基于最新的Apache和Tomcat,具体是2011年4月20日最新的Tomcat和Apache集群和负载均衡配置. 准备环境 Apache Apache是ht ...

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

    1.本文Apache+Tomcat集群配置 基于最新的Apache和Tomcat,具体是2011年4月20日最新的Tomcat和Apache集群和负载均衡配置. 准备环境 Apache Apache是 ...

  6. Apache负载均衡与Tomcat集群配置学习(Windows环境)

    本文主要参考自http://www.iteye.com/topic/985404?dhcc,经由实际操作配置操并记录而成. 由于最近的一个Java开发项目用到了Tomcat中间件作为web服务器,刚开 ...

  7. Spring+quartz 实现定时任务job集群配置

    为什么要有集群定时任务? 因为如果多server都触发相同任务,又同时执行,那在99%的场景都是不适合的.比如银行每晚24:00都要汇总营业额.像下面3台server同时进行汇总,最终计算结果可能是真 ...

  8. Apache+tomcat+mod_jk+centos6.2负载均衡集群配置--转载

    转载地址:http://blog.163.com/chenhui_java/blog/static/17267249420128101191860/ 注: 由于长期受转载毒害,所以本人日志均是原创:其 ...

  9. window xp Apache与Tomcat集群配置--转载

    转载地址:http://www.cnblogs.com/obullxl/archive/2011/06/09/apache-tomcat-cluster-config.html 一. 环境说明 Win ...

随机推荐

  1. java中equals和==区别

    equals 方法是 java.lang.Object 类的方法. 有两种用法说明: (1)对于字符串变量来说,使用“==”和“equals()”方法比较字符串时,其比较方法不同. “==”比较两个变 ...

  2. SVM python小样例

    SVM有很多种实现,但是本章只关注其中最流行的一种实现,即序列最小化(SMO)算法在此之后,我们将介绍如何使用一种称为核函数的方式将SVM扩展到更多的数据集上基于最大间隔的分割数据优点:泛化错误率低, ...

  3. easyui tree datagrid动态添加表头和表格数据,动态弹出框,修改和删除按钮

    1.要有获取表头的URL和表格的URL 背景:点击树的一个节点,就加载一个表格,这个表格是动态的,表头和表格数据都是动态的 解决方案:需要两个URL,一个是获取表头的URL,一个是获取表格数据的URL ...

  4. navicat常用快捷键及注意事项

    常用快捷键: 1. ctrl + q: 打开新查询窗口 2. ctrl + r: 运行当前窗口内的所有语句 3. ctrl + w: 关闭当前窗口 4. F6: 打开一个mysql命令行窗口 ---- ...

  5. day10 消息队列,多进程和多线程以及协程,异步IO,事件驱动等

    回顾一下线程和进程 线程与进程的区别 守护线程: 队列: 两种方式: 先进先出  # 后入先出   #卖水果,后来的来的是新的 生产者消费者模型: 生产包子, 吃包子 事件 event: 红绿灯模型 ...

  6. laravel5.2总结--blade模板

    ## 1.基本用法 ``` ##情形1 $name = laravel5 <div class="title"> {{$name}} {{$name}}</div ...

  7. cookie注意事项

    cookie是在 HTTP 协议下,服务器或脚本可以维护客户工作站上信息的一种方式. 四种会话跟踪技术(URL重写.隐藏表单域.Cookie.Session) 服务端技术:URL重写,Session, ...

  8. java 课堂笔记

  9. java基础-容器

    已经写了一段时间JAVA代码了,但仔细想来,却发现对JAVA的很多方面还是一片迷茫. 利用周末补一下基础知识吧. 大致列一下这个周末需要学习的内容 1 容器 (本节内容) 2 线程 3 流 目录 1 ...

  10. 通过sql查询rman备份信息

    通过sql查询rman备份信息 查看所有备份集 SELECT A.RECID "BACKUP SET", A.SET_STAMP, DECODE (B.INCREMENTAL_LE ...