美文网首页
Spring Session 实现分布式会话管理

Spring Session 实现分布式会话管理

作者: 善思者_tin | 来源:发表于2020-03-24 09:58 被阅读0次

    1、分布式会话管理概述

    在Web项目开发中,会话管理是一个很重要的部分,用于存储与用户相关的数据。通常是由符合session规范的容器来负责存储管理,也就是一旦容器关闭,重启会导致会话失效。因此打造一个高可用性的系统,必须将session管理从容器中独立出来。

    2、分布式会话管理的解决方案选用

    实现方案有很多种,下面简单介绍下:

    第一种是使用容器扩展来实现,大家比较容易接受的是通过容器插件来实现,比如基于Tomcat的tomcat-redis-session-manager,基于Jetty的jetty-session-redis等等。好处是对项目来说是透明的,无需改动代码。不过前者目前还不支持Tomcat 8,或者说不太完善。个人觉得由于过于依赖容器,一旦容器升级或者更换意味着又得从新来过。并且代码不在项目中,对开发者来说维护也是个问题。

    第二种是自己写一套会话管理的工具类,包括Session管理和Cookie管理,在需要使用会话的时候都从自己的工具类中获取,而工具类后端存储可以放到Redis中。很显然这个方案灵活性最大,但开发需要一些额外的时间。并且系统中存在两套Session方案,很容易弄错而导致取不到数据。

    第三种是使用框架的会话管理工具,也就是本文要说的spring-session,可以理解是替换了Servlet那一套会话管理,既不依赖容器,又不需要改动代码,并且是用了spring-data-redis那一套连接池,可以说是最完美的解决方案。当然,前提是项目要使用Spring Framework才行。

    3、为什么使用Spring Session?

    Spring Session为企业级Java应用的session管理带来了革新,使得以下的功能更加容易实现:

    将session所保存的状态卸载到特定的外部session存储中,如Redis或Apache Geode中,它们能够以独立于应用服务器的方式提供高质量的集群。

    当用户使用WebSocket发送请求的时候,能够保持HttpSession处于活跃状态。

    在非Web请求的处理代码中,能够访问session数据,比如在JMS消息的处理代码中。

    支持每个浏览器上使用多个session,从而能够很容易地构建更加丰富的终端用户体验。

    控制session id如何在客户端和服务器之间进行交换,这样的话就能很容易地编写Restful API,因为它可以从HTTP 头信息中获取session id,而不必再依赖于cookie。

    4、Spring Session分布式会话解决方案

    web.xml配置:

    springSessionRepositoryFilterorg.springframework.web.filter.DelegatingFilterProxyspringSessionRepositoryFilter/*

    编写配置,注解@EnableRedisHttpSession通过Import,引入了RedisHttpSessionConfiguration配置类。该配置类通过@Bean注解,向Spring容器中注册了一个SessionRepositoryFilter(SessionRepositoryFilter的依赖关系:SessionRepositoryFilter --> SessionRepository --> RedisTemplate --> RedisConnectionFactory)。

    相关文章

      网友评论

          本文标题:Spring Session 实现分布式会话管理

          本文链接:https://www.haomeiwen.com/subject/qjcmxhtx.html