安裝兩臺memcache,基于tomcat做會話同步;(只對動態(tài)內容緩存,用于追蹤用戶會話)
前提:
- 兩個tomcat節(jié)點:172.16.100.7(tomcatA.magedu.com),172.16.100.8(tomcatB.magedu.com)
- 兩個memcached節(jié)點:172.16.100.9, 172.16.100.10
- 一個負載均衡節(jié)點:172.16.100.6
- 兩臺安裝完tomcat,再yum安裝memcached即可;memcached配置文件:/etc/sysconfig/memcached 建議修改緩存空間大小CACHESIZE,M為單位
memcached-session-manager項目地址 - 教室環(huán)境下下載安裝包,lftp 172.18.0.1:/pub/Sources/7.x86_64/msm> mget * 其他環(huán)境參考上述項目地址網(wǎng)站下載
- 現(xiàn)在兩臺tomcat版本都為7,所以刪除掉不需要的memcached依賴包:rm -rf memcached-session-manager-tc8-1.8.3.jar
- 然后將幾類包放置到tomcat對應的lib相關目錄下:mv *.jar /usr/share/tomcat/lib
- 隨后修改tomcat配置文件,添加在Host上下文中:
<Context path="/test" docBase="/usr/share/tomcat/webapps/test" reloadable="true">
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:172.16.100.9:11211,n2:172.16.100.10:11211"
failoverNodes="n1"
requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"
/>
</Context>
- 分別為兩個context提供測試頁面:
- tomcatA:
mkdir -pv /usr/local/tomcat/webapps/test/WEB-INF/{classes,lib}
vim /usr/share/tomcat/webapps/test/index.jsp
<%@ page language="java" %>
<html>
<head><title>TomcatA</title></head>
<body>
<h1><font color="red">TomcatA.magedu.com</font></h1>
<table align="centre" border="1">
<tr>
<td>Session ID</td>
<% session.setAttribute("magedu.com","magedu.com"); %>
<td><%= session.getId() %></td>
</tr>
<tr>
<td>Created on</td>
<td><%= session.getCreationTime() %></td>
</tr>
</table>
</body>
</html>
- 上述為tomcat1,tomcat2節(jié)點和memcached2與上述安裝配置基本一致,就/usr/share/tomcat/webapps/test/index.jsp頁面信息有些改變:
<%@ page language=”java” %>
<html>
<head><title>TomcatB</title></head>
<body>
<h1><font color=”blue”>TomcatB.magedu.com</font></h1>
<table align=”centre” border=”1″>
<tr>
<td>Session ID</td>
<% session.setAttribute(“magedu.com”,”magedu.com”); %>
<td><%= session.getId() %></td>
</tr>
<tr>
<td>Created on</td>
<td><%= session.getCreationTime() %></td>
</tr>
</table>
</body>
</html>
- 最后在172.16.100.6的nginx上配置反向代理的負載均衡內容即可,測試訪問:
注意會話內容是一致