apache+tomcat+session(JK实现方式)

测试的软件版本为:
apache:2.2
tomcat:5.5
jk:mod_jk-1.2.30-httpd-2.2.3.so

[b]1.在httpd.conf底部加上[/b]
LoadModule jk_module modules/mod_jk.so#加载JK模块
JkWorkersFile conf/workers.properties#tomcat工作配置
JkLogFile logs/mod_jk.log#jk工作日志
JkMount /*.jsp controller#url是.jsp结束的交给tomcat处理

[b]2.在conf目录新建workers.properties文件,添加内容[/b]worker.list=controller,t1,t2
#========tomcat1========
worker.t1.port=8009 #ajp13 端口号,在tomcat下server.xml配 置,默认8009
worker.t1.host=localhost #tomcat的主机地址,如不为本机,请填写ip地址
worker.t1.type=ajp13
worker.t1.lbfactor = 1 #server的加权比重,值越高,分得的请求越多
#========tomcat2========
worker.t2.port=8010 #ajp13 端口号,在tomcat下server.xml配置,
worker.t2.host=localhost #tomcat的主机地址,如不为本机,请填写ip地址
worker.t2.type=ajp13
worker.t2.lbfactor = 1 #server的加权比重,值越高,分得的请求越多
#========controller,负载均衡控制器========
worker.controller.type=lb
worker.controller.balanced_workers=t1,t2 #指定分担请求的tomcat
worker.controller.sticky_session=false

[b]3.修改tomcat1的server.xml配置[/b]
找到<Engine name="Catalina" defaultHost="localhost">后修改为
<Engine name="Catalina" defaultHost="localhost" jvmRoute="t1">
把Cluster的注解注销掉,这里主要是为了tomcat的session同步

[b]4.修改tomcat2的server.xml配置[/b]
找到<Connector port="8009" enableLookups="false" redirectPort="8443" protocol="AJP/1.3" /> 后修改8009为8010
找到<Engine name="Catalina" defaultHost="localhost">后修改为
<Engine name="Catalina" defaultHost="localhost" jvmRoute="t2">
把Cluster 的注解注销掉,修改tcpListenPort 端口号为4002,这里主要是为了tomcat的session同步

[b]5.在tomcat1和tomcat2的server.xml中添加项目[/b]
<Context docBase="D:/eclipse/workspace/lb/WebRoot" distributable="true" path="/xxx"/>
注意两个tomcat中的path必须一致,不然会报错(Context manager doesn't exist).只有path一致,两个tomcat才能同步session

[b]6.注意事项:[/b]
6.1 你的所有会话属性值必须实现java.io.Serializable (就是需要同步的bean必须要实现这个接口)
6.2 在你的web项目的web.xml中加入 <distributable/> 或者在tomcat 的service.xml的项目配置中加入distributable="true" 例如:<Context docBase="D:/eclipse/workspace/lb/WebRoot" distributable="true" path="/xxx"/>
6.3 如果两个tomcat在不同的物理机器上(不同的IP),必须保证时间一致,可以通过网络时间服务(NTP)同步操作系统的时间
6.4 jk2版本已经被废除。
6.5 tomcat5默认的session复制是现实了JVM内存中复制,在JVM内存中复制SESSION状态,使用tomcat5安装带的SimpleTcpCluster 和 SimpleTcpClusterManager 类.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值