使用Spring Session做分布式会话管理
2016-03-10 18:54
357 查看
使用Spring Session做分布式会话管理
在Web项目开发中,会话管理是一个很重要的部分,用于存储与用户相关的数据。通常是由符合session规范的容器来负责存储管理,也就是一旦容器关闭,重启会导致会话失效。因此打造一个高可用性的系统,必须将session管理从容器中独立出来。而这实现方案有很多种,下面简单介绍下:第一种是使用容器扩展来实现,大家比较容易接受的是通过容器插件来实现,比如基于Tomcat的tomcat-redis-session-manager,基于Jetty的jetty-session-redis等等。好处是对项目来说是透明的,无需改动代码。不过前者目前还不支持Tomcat 8,或者说不太完善。个人觉得由于过于依赖容器,一旦容器升级或者更换意味着又得从新来过。并且代码不在项目中,对开发者来说维护也是个问题。
第二种是自己写一套会话管理的工具类,包括Session管理和Cookie管理,在需要使用会话的时候都从自己的工具类中获取,而工具类后端存储可以放到Redis中。很显然这个方案灵活性最大,但开发需要一些额外的时间。并且系统中存在两套Session方案,很容易弄错而导致取不到数据。
第三种是使用框架的会话管理工具,也就是本文要说的spring-session,可以理解是替换了Servlet那一套会话管理,既不依赖容器,又不需要改动代码,并且是用了spring-data-redis那一套连接池,可以说是最完美的解决方案。当然,前提是项目要使用Spring Framework才行。
这里简单记录下整合的过程:
如果项目之前没有整合过spring-data-redis的话,这一步需要先做,在maven中添加这两个依赖:
然后是在web.xml中添加一个session代理filter,通过这个filter来包装Servlet的getSession()。需要注意的是这个filter需要放在所有filter链最前面。
验证:使用redis-cli就可以查看到session key了,且浏览器Cookie中的jsessionid已经替换为session。
来自:Dorole's Blog
相关文章推荐
- spring 面试题
- java线程(1)-线程同步
- Java流程控制语句
- JDK的安装与第一个Java小程序的运行(在win7和win10上检验过)
- JAVA学习笔记
- Java IO复习(一)
- leetcode:Remove Linked List Elements 【Java】
- String的按值传递,java传参都是传值
- java学习日记——java中的多态
- spring MVC解决中文传参乱码问题
- Java进制的转换
- Java运算符
- 在Eclipse中编写servlet时出现"The import javax.servlet cannot be resolved" 问题解决办法
- Java Socket通信小结
- 使用Java VisualVM监控远程JVM
- 《THINKING IN JAVA》随笔
- Java编程思想学习(三) 初始化与清理
- Eclipse工作常用技巧总结
- Spring源码解析 - BeanFactory接口体系解读
- JAVA中的命令模式实例教程