apache http server下载地址
http://httpd.apache.org/download.cgi#apache22
这里下载的是httpd-2.2.21-win32-x86-openssl-0.9.8r.msi
tomcat下载地址
http://tomcat.apache.org/download-70.cgi
这里下载的是http://apache.etoak.com/tomcat/tomcat-7/v7.0.23/bin/apache-tomcat-7.0.23.zip
jk下载地址
http://labs.renren.com/apache-mirror//tomcat/tomcat-connectors/jk/binaries/windows/
这里下载的是tomcat-connectors-1.2.32-windows-i386-httpd-2.2.x.zip
首先安装apache
然后解压缩tomcat,并将tomcat复制出两份
解压缩jk
将mod_jk.so文件复制到apache/modules文件夹
修改apache/conf/httpd.conf文件
在当前文件最后写入
include conf/mod_jk.conf
在apache/conf目录中,建立mod_jk.conf文件,文件内容如下
#加载mod_jk Module
LoadModule jk_module modules/mod_jk.so
#指定 workers.properties文件路径
JkWorkersFile conf/workers.properties
#指定那些请求交给tomcat处理,"controller"为在workers.propertise里指定的负载分配控制器
JkMount /**.do controller
JkMount /**.html controller
JkMount /* controller
在apache/conf目录中,建立workers.properties文件,内容如下
worker.list = controller,tomcat1,tomcat2 #server 列表
#========tomcat1========
worker.tomcat1.port=18009 #ajp13 端口号,在tomcat下server.xml配置,默认8009
worker.tomcat1.host=localhost #tomcat的主机地址,如果不是本机,请填写ip地址
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor = 1 #server的加权比重,值越高,分得的请求越多
#========tomcat2========
worker.tomcat2.port=28009 #ajp13 端口号,在tomcat下server.xml配置,默认8009
worker.tomcat2.host=localhost #tomcat的主机地址,如果不是本机,请填写ip地址
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor = 1 #server的加权比重,值越高,分得的请求越多
#========controller,负载均衡控制器========
worker.controller.type=lb
worker.controller.balanced_workers=tomcat1,tomcat2 #指定分担请求的tomcat
worker.controller.sticky_session=1
修改第一个tomcat/conf/server.xml
将
<Server port="8005" shutdown
改为
<Server port="18005"
将
<Connector port="8080" protocol="HTTP/1.1"
改为
<Connector port="18080"
将
<Connector port="8009" protocol="AJP/1.3"
改为
<Connector port="18009"
将
<Engine name="Catalina" defaultHost="localhost"
增加jvmRoute
<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1"
在<Engine name="Catalina"这个标签的下面添加
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
channelSendOptions="8">
<Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"/>
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership className="org.apache.catalina.tribes.membership.McastService"
address="228.0.0.4"
port="45564"
frequency="500"
dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto"
port="14000"
autoBind="100"
selectorTimeout="5000"
maxThreads="6"/>
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
</Channel>
<Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
filter=""/>
<Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>
<ClusterListener className="org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
第一个tomcat配置完毕
修改第二个tomcat/conf/server.xml
将
<Server port="8005" shutdown
改为
<Server port="28005"
将
<Connector port="8080" protocol="HTTP/1.1"
改为
<Connector port="28080"
将
<Connector port="8009" protocol="AJP/1.3"
改为
<Connector port="28009"
将
<Engine name="Catalina" defaultHost="localhost"
增加jvmRoute
<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat2"
在<Engine name="Catalina"这个标签的下面添加
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
channelSendOptions="8">
<Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"/>
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership className="org.apache.catalina.tribes.membership.McastService"
address="228.0.0.4"
port="45564"
frequency="500"
dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto"
port="24000"
autoBind="100"
selectorTimeout="5000"
maxThreads="6"/>
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
</Channel>
<Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
filter=""/>
<Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>
<ClusterListener className="org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
第二个tomcat配置完毕
在项目的web.xml的最下方,添加支持session复制的语句
<distributable />
</web-app>
集群和session复制配置完毕,将war包分别部署到两个tomcat的webapps目录就可以实现项目的负载均衡和session复制。
一个很重要的问题,要实现session复制,必须序列化所有要存到session中的东西才行,例如
SessionInfo sessionInfo = new SessionInfo();
session.setAttribute("sessionInfo",sessionInfo);
这个sessionInfo必须 implements java.io.Serializable 才可以进行session复制,否则报错。
转自:http://yusun.blog.163.com/blog/static/2017440762012042856982/
分享到:
相关推荐
11. **集群与负载均衡**:Tomcat支持集群配置,可以在多个实例之间共享session,实现故障转移和负载均衡。 12. **WebSocket支持**:Tomcat 7开始支持WebSocket协议,允许双向通信,为实时Web应用提供了基础。 以上...
Tomcat7.0支持集群部署,通过复制Session数据实现故障转移和负载均衡。可以借助mod_proxy或其它负载均衡器配合实现,以提高系统的可用性和扩展性。 八、JNDI资源 Tomcat7.0提供JNDI(Java Naming and Directory ...
- **Apache版本**: Apache 2.2.x - **Tomcat版本**: Tomcat 6.0 或 Tomcat 7.0 - **集群模式**: 使用mod_proxy模块实现负载均衡 - **环境**: 本案例基于本地环境配置,若需要远程访问,请将`localhost`替换为实际IP...
首先,Tomcat 7.0.x系列属于Tomcat 7的主要分支,支持Java Servlet 3.0、JavaServer Pages (JSP) 2.2以及Expression Language (EL) 2.2等技术规范。这些规范使得开发者可以创建动态、交互式的Web应用程序。 1. **...
4. **Clustering和Session复制**:为了提高可用性和负载均衡,Tomcat 7.0支持集群部署,可以将用户的会话信息在多个Tomcat实例之间复制,实现故障转移和负载均衡。 5. **Security增强**:Tomcat 7.0增强了安全管理...
Apache Tomcat 7.0是Java Servlet和JavaServer Pages(JSP)的开源Web应用服务器,由Apache软件基金会开发并维护。它是一个轻量级的应用服务器,主要用于运行Java的动态Web内容,如JSP和Servlet。Tomcat 7.0免安装版...
1. 通过复制和同步session数据,可以实现Tomcat集群,提高可用性和扩展性。 2. 配合负载均衡器,可以将请求分发到不同的Tomcat实例,以平衡负载。 总结,Apache Tomcat 7.0.6是一个强大的Java Web服务器,提供了...
Tomcat-7.0.x是Apache Tomcat服务器的一个版本,它是一个开源的、实现了Java Servlet和JavaServer Pages(JSP)规范的应用服务器。这个版本的Tomcat源码是开发者深入理解Web应用服务器工作原理和优化应用性能的重要...
7. **集群和负载均衡**:Tomcat支持集群配置,可以在多个Tomcat实例之间实现 session复制和负载均衡,提高系统的可用性和可靠性。 8. **连接器(Connector)**:Tomcat使用不同的连接器处理不同类型的网络协议,如...
9. **集群与负载均衡**:Tomcat支持集群配置,通过复制session和负载均衡,可以实现多个Tomcat实例间的协同工作,提高可用性和响应速度。 10. **Maven集成**:开发者可以使用Maven的Tomcat插件,在开发过程中直接在...
- **Session复制**:通过集群配置,实现在不同Tomcat实例间共享用户会话信息。 8. **集成开发环境(IDE)支持** - Eclipse、IntelliJ IDEA等IDE提供了与Tomcat的集成,方便调试和部署Web应用。 9. **故障排查** ...
本文介绍了使用Apache反向代理配置集群,基于mod_proxy+Apache 2.2.16+Tomcat 7实现负载均衡与集群配置。 一、 背景简介 大多数企业应用都希望能做到7*24小时不间断运行。要保持如此高的可用性并非易事,比较常见...
对于高可用性和负载均衡,可以配置Tomcat集群,通过复制session数据和智能路由请求到不同的服务器实例来实现。 10. **监控与管理**: 通过内置的Manager应用,管理员可以监控应用状态,部署或卸载应用,以及执行...
默认情况下,Tomcat会将session信息存储在内存中,但这在多台服务器的集群环境中会导致session不一致。为了解决这个问题,我们可以将session信息存储在一个集中式的数据存储系统中,比如Redis。 二、Redis作为...
本文将详细介绍如何在Apache Tomcat 7.0和Apache 2.2环境下配置负载均衡,并实现session复制。 **环境配置** 1. 安装JDK1.6:首先确保安装了Sun JDK 1.6,将其安装在默认路径,例如`C:\Program Files\Java\jdk1.6.0...
这包括调整连接器配置(如最大线程数、超时设置)、启用压缩、使用NIO连接器而非BIO、减少session复制(在集群环境中)以及定期更新到官方发布的最新安全补丁。 此外,Tomcat 7.0.41还支持与其它Java EE组件的集成...
这里提到的"Tomcat8+Redis Session同步"就是一种解决策略,它利用Redis作为中央缓存来存储Session数据,从而在Tomcat8集群中实现Session的共享。 **一、Tomcat8** Tomcat8是Apache软件基金会的Tomcat服务器的第8个...
9. **集群与负载均衡**:Tomcat支持通过集群实现高可用性和负载均衡,但需要配置复制和session管理策略。 10. **错误处理**:Tomcat允许自定义错误页面,这在web.xml中通过`error-page`元素定义。 总的来说,...