使用memcached實現tomcat集群session共享


環境centos6.7,下載安裝必要的軟件:yum -y install epel-release(tomcat7在此源上,tomcat7是現在主流版本)

yum -y install tomcat  直接下載tomcat7,   yum -y install java-1.7.0-openjdk-devel (tomcat需要運行在java虛擬機上)

vim /etc/tomcat/server.xml   修改配置文件

      <Host name="web.com"  appBase="/data/webapps/" unpackWARs="true" autoDeploy="true">
      <Context path="" docBase="/data/webapps" reloadable="true" >
        <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" memcachedNodes="n1:192.168.238.250:11211,n2:192.168.238.251:11211" failoverNodes="n2" requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$" transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"/>
      </Context>
      </Host>

上面的字自己都看不清還是貼個圖吧

自定義了一台虛擬主機:<Host name="web.com"  appBase="/data/webapps/" unpackWARs="true" autoDeploy="true">

在此虛擬主機上添加了Context:<Context path="" docBase="/data/webapps" reloadable="true" >

關鍵是manager這段:

  為manager取個全局唯一名字:<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"

  定義有哪些memcached服務器節點:memcachedNodes="n1:192.168.238.250:11211,n2:192.168.238.251:11211"

  定義備用節點:failoverNodes="n2"

  對那些請求url忽略:requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"

  固定格式:transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"/>

  

把默認虛擬主機定義為web.com:

JvmRoute="TomcatA" 是在請求web.com的session id中添加JvmRoute="TomcatA",此實驗中可不用添加

創建頁面資源:mkdir -p /data/webapps/{WEB-INF,classes,lib}    cd /data/webapps/  vim index.jsp

jsp頁面資源如下

<%@ page language="java" %> <html> <head><title>TomcatA</title></head> <body> <h1><font color="red">TomcatA.test</font></h1> <table align="centre" border="1"> <tr> <td>Session ID</td> <% session.setAttribute("test","test"); %> <td><%= session.getId() %></td> </tr> <tr> <td>Created on</td> <td><%= session.getCreationTime() %></td> </tr> </table> </body> </html>

貼個圖:

下載如下幾個包:javolution-5.5.1   memcached-session-manager-1.8.2   memcached-session-manager-tc7-1.8.2

msm-javolution-serializer-1.8.2  spymemcached-2.10.2    這幾個包作用:java通過memcached實現session管理

上面這幾個包的下載地址:https://github.com/magro/memcached-session-manager/wiki/SetupAndConfiguration

把上面幾個包放在/usr/share/tomcat/lib/ 目錄下 (注意上面幾個包不要下錯了,這又是個潛在的坑)

 

 

這幾個包的版本一定要對,我在這踩了一天的坑,如果你的是tomcat8,對應的memcached-session-manager-tc8-1.8.2

兩台memcached各自放在兩台tomcat上,使用yum -y install memcached下載就行了

把上面的步驟在tomcatA上的步驟,在tomcatB上執行一遍,tomcatB上的jsp頁面資源中的TomcatA改為TomcatB,red改為blue

前端再架設一台Nginx實現負載均衡,啟動memcached,啟動tomcat,啟動Nginx,去瀏覽器驗證

 

驗證成功,Session ID保持一樣


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM