apache+tomcat實(shí)現(xiàn)session共享

apache+tomcat上篇文章,實(shí)現(xiàn)了負(fù)載均衡,現(xiàn)在我們實(shí)現(xiàn)session共享

創(chuàng)新互聯(lián)建站專業(yè)為企業(yè)提供沙灣網(wǎng)站建設(shè)、沙灣做網(wǎng)站、沙灣網(wǎng)站設(shè)計(jì)、沙灣網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)與制作、沙灣企業(yè)網(wǎng)站模板建站服務(wù),10余年沙灣做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。

一、tomcat集群配置,session 同步配置:

tomcat1配置  
A、修改Engine節(jié)點(diǎn)信息: <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">
B、去掉<Cluster>  <\Cluster> 的注釋符
C、修改Cluster 節(jié)點(diǎn)信息
<Membership              
className="org.apache.catalina.cluster.mcast.McastService"                

mcastBindAddress="127.0.0.1"

#IP自己配置,遠(yuǎn)程的話寫遠(yuǎn)程IP              
mcastAddr="224.0.0.1"                
mcastPort="45564"    
mcastFrequency="500"                
mcastDropTime="3000"/>
     <Receiver          
className="org.apache.catalina.cluster.tcp.ReplicationListener"                

tcpListenAddress="127.0.0.1"                
tcpListenPort="4001"                
tcpSelectorTimeout="100"                
tcpThreadCount="6"/>

tomcat2配置:
A、修改Engine節(jié)點(diǎn)信息: <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat2">
B、去掉<Cluster>  <\Cluster> 的注釋符
C、修改Cluster 節(jié)點(diǎn)信息
<Membership      
className="org.apache.catalina.cluster.mcast.McastService"
mcastBindAddress="127.0.0.1"

#IP自己配置
mcastAddr="224.0.0.1"
mcastPort="45564"
mcastFrequency="500"
mcastDropTime="3000"/>
<Receiver          
className="org.apache.catalina.cluster.tcp.ReplicationListener"          
tcpListenAddress="127.0.0.1"

#IP自己配置
tcpListenPort="4002"

# 一定要改
tcpSelectorTimeout="100"
tcpThreadCount="6"/>


修改web應(yīng)用里面WEB-INF目錄下的web.xml文件,加入標(biāo)簽
<distributable/>
直接加在</web-app>之前就可以了
做tomcat集群必須需要這一步,否則用戶的session就無法正常使用。
注意事項(xiàng)

1、mcastAddr="224.0.0.1"這主廣播地址因此需要開啟網(wǎng)卡組播功能

route add -net 224.0.0.0 netmask 240.0.0.0 dev eth0

分別在各機(jī)器上運(yùn)行

2、查看端口情況:Netstat –antl |grep 4001同步監(jiān)聽的端口(2臺tomcat在不同機(jī)器情況下)
tocat1
apache+tomcat實(shí)現(xiàn)session共享
tomcat2
apache+tomcat實(shí)現(xiàn)session共享
3、測試廣播:

java -cp tomcat-replication.jar MCaster 224.0.0.1 45564 Terminal1

java -cp tomcat-replication.jar MCaster 224.0.0.1 45564 Terminal2

如果不報(bào)錯則能正常廣播tomcat-replication.jar下載:[url]http://cvs.apache.org/~fhanik/tomcat-replication.jar[/url]如果是二臺機(jī)器,可以用tcpdump抓取包


二、測試集群及session同步

在2個tomct的webapps下新建test目錄目錄下建WEB-INF目錄下的web.xml文件

<web-app xmlns="http://java.sun.com/xml/ns/j2ee"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee [url]http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd[/url]"

version="2.4">

<display-name>TomcatDemo</display-name>

<distributable/>

</web-app>

再在webapps下建立print.jsptest.jsp

Print.jsp :

<%

System.out.println("http://andashu.blog.51cto.com/);

%>

test.jsp:
<%@ page contentType="text/html; charset=GBK" %>
<%@ page import="java.util.*" %>
<html><head><title>Cluster App Test</title></head>
<body>
Server Info:
<%
out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");%>
<%
 out.println("<br> ID " + session.getId()+"<br>");
 String dataName = request.getParameter("dataName");
 session.setAttribute("myname","session?");
 if (dataName != null && dataName.length() > 0) {
    String dataValue = request.getParameter("dataValue");
    session.setAttribute(dataName, dataValue);
 }
 out.print("<b>Session P±?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">
   3?<input type=text size=20 name="dataName">
    <br>
   ?:<input type=text size=20 name="dataValue">
    <br>
   <input type=submit>
  </form>
</body>

</html>



重啟所有的服務(wù)。
訪問[url]http://192.168.19.199/test/print.jsp[/url]
如圖可以看出tomcat集群配置完成
apache+tomcat實(shí)現(xiàn)session共享apache+tomcat實(shí)現(xiàn)session共享
Session復(fù)制的查看:
在同一窗口,輸入名稱和值,
在2個tomcat日志里能看到同樣內(nèi)容的日志,就表明成功了。


當(dāng)前標(biāo)題:apache+tomcat實(shí)現(xiàn)session共享
路徑分享:http://bm7419.com/article6/giphog.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷定制開發(fā)、Google、商城網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)動態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)