日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

基于tomcat集群做session共享

發(fā)布時間:2024/8/26 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 基于tomcat集群做session共享 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

前端代理服務(wù)器nginx:192.168.223.136

tomcat服務(wù)器:采用的一臺多實例192.168.223.146:8081,192.168.223.146:8082(如何構(gòu)建多實例tomcat,請參考前面的文章)

首先查看下tomcat的webapps目錄架構(gòu):

[root@wadeson tomcat-instance]# pwd
/usr/local/tomcat-instance
[root@wadeson tomcat-instance]# ll
總用量 24
-rwxr-xr-x. 1 root root 165 8月 9 15:31 start-tomcat1.sh
-rwxr-xr-x. 1 root root 165 8月 9 16:18 start-tomcat2.sh
-rwxr-xr-x. 1 root root 165 8月 9 15:38 stop-tomcat1.sh
-rwxr-xr-x. 1 root root 165 8月 9 16:18 stop-tomcat2.sh
drwxr-xr-x. 7 root root 4096 8月 9 15:45 tomcat1
drwxr-xr-x. 7 root root 4096 8月 9 16:12 tomcat2
[root@wadeson tomcat-instance]# cd tomcat1/webapps/
[root@wadeson webapps]# tree .
.
├── myapp
│?? └── test.jsp
└── ROOT
  ├── classes
  ├── index.jsp
  ├── lib
  ├── META-INF
  └── WEB-INF

?由于安裝的tomcat是8.5版本的,所以查看下官方文檔:https://tomcat.apache.org/tomcat-8.5-doc/cluster-howto.html

構(gòu)建tomcat集群只需要如下幾步:

1、添加集群組件信息(在host或者engine組件下添加進去就行)

<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="4000"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.MessageDispatchInterceptor"/></Channel><Valve className="org.apache.catalina.ha.tcp.ReplicationValve"filter=""/><Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/><Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"tempDir="/tmp/war-temp/"deployDir="/tmp/war-deploy/"watchDir="/tmp/war-listen/"watchEnabled="false"/><ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/></Cluster>
以上是直接摘自官網(wǎng),需要稍微做下修改address="auto",address="228.0.0.4"
2、需要在各自的應(yīng)用程序目錄下面為web.xml添加一行<distributable/>元素
  • Make sure your?web.xml?has the?<distributable/>?element

現(xiàn)在直接貼自己的配置tomcat1:

<Host name="localhost" appBase="/usr/local/tomcat-instance/tomcat1/webapps" ?unpackWARs="true" autoDeploy="true">

? ?<Context path="" docBase="ROOT" reloadable="true"/>
? <Valve className="org.apache.catalina.valves.AccessLogValve" directory="/usr/local/tomcat-instance/tomcat1/logs"
  prefix="localhost_access_log" suffix=".txt"
  pattern="%h %l %u %t &quot;%r&quot; %s %b" />
? <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="192.168.223.146" ? ? ? ? ? ? ? ? 由于是一臺主機上的兩個tomcat實例,所以這里的cluster添加的內(nèi)容都一樣
    port="4000"
    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.MessageDispatchInterceptor"/>
  </Channel>

  <Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
  filter=""/>
  <Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>

  <Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"
    tempDir="/tmp/war-temp/"
    deployDir="/tmp/war-deploy/"
    watchDir="/tmp/war-listen/"
    watchEnabled="false"/>

  <ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
</Host>

然后在應(yīng)用程序ROOT下面的WEB-INF的下面添加自己的web.xml:

[root@wadeson tomcat-instance]# ll tomcat1/webapps/ROOT/WEB-INF/web.xml
-rw-------. 1 root root 168271 8月 10 16:50 tomcat1/webapps/ROOT/WEB-INF/web.xml

  <distributable/> ? ? ? ? 這就是需要添加的一行內(nèi)容
</web-app>

于是配置tomcat1實例完成,tomcat2的配置和tomcat1一致(由于是同一主機的不同實例)

?

于是進行訪問:

可以看見session的id值兩者相同,只是后面的tomcat不一致,于是session共享的功能就達成了,然后配置nginx進行代理轉(zhuǎn)發(fā):

upstream backserver {
  server 192.168.223.146:8081 weight=1;
  server 192.168.223.146:8082 weight=1;
}

server {
  listen 80;
  server_name 192.168.223.136;

  location / {
    root html;
    index index.html index.htm;
    proxy_pass http://backserver/;
  }

測試效果:

?

轉(zhuǎn)載于:https://www.cnblogs.com/jsonhc/p/7344241.html

總結(jié)

以上是生活随笔為你收集整理的基于tomcat集群做session共享的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。