tomcat的session保存在数据库中,不是很复杂,写下来供大家参考。
准备工作:
- 两架Ubuntu Server 12.04 64位,确定两级服务器可以互相ping的通并属于同一个网段
- 安装jdk1.6或者jdk1.7
- 安装tomcat 6或者tomcat7
- 测试multicast 参考文章http://www.javalinux.me/archives/840.html
- 在你的程序中的web.xml中加入<distributable/> 并测试是否可以运行
- 确认所有的session 属性全部有implements java.io.Serializable
1. 修改conf/context.xml 加入如下内容:
01
02
03
04
05
06
07
08
09
10
11
12
13
14
|
< Manager className = 'org.apache.catalina.session.PersistentManager' saveOnRestart = 'false' minIdelSwap = '0' maxIdleSwap = '0' maxIdleBackup = '1' > < Store className = "org.apache.catalina.session.JDBCStore" driverName = "com.mysql.jdbc.Driver" connectionURL = "jdbc:mysql://localhost/tomcat_session?user=root&password=123456" sessionTable = "sessions" sessionIdCol = "session_id" sessionDataCol = "session_data" sessionValidCol = "valid_session" sessionMaxInactiveCol = "max_inactive" sessionLastAccessedCol = "last_access" checkInterval = "10" sessionAppCol = 'app_name' /> </ Manager > |
这种配置将会把所有这个tomcat下面的session全部复制到数据库中,如果你只想要复制某个程序的话,将这个context.xml 保存到META-INF里面
2. 将mysql的jdbc 驱动复制到tomcat/lib下面
3. 修改catalina.sh, 在其最上面加入
1
|
JAVA_OPTS= '-Dorg.apache.catalina.session.StandardSession.ACTIVITY_CHECK=true' |
完毕,你现在可以部署程序测试了
参考文章:http://www.intelligrape.com/blog/2010/07/21/tomcat-6-session-persistence-through-jdbcstore/
http://tomcat.apache.org/tomcat-6.0-doc/config/manager.html
http://www.datadisk.co.uk/html_docs/java_app/tomcat6/tomcat6_clustering.htm