码迷,mamicode.com
首页 > 编程语言 > 详细

Spring Session Data Redis实现session共享

时间:2018-02-26 21:50:02      阅读:323      评论:0      收藏:0      [点我收藏+]

标签:href   mys   work   分布   创建   就是   targe   ica   cookie   

1.前言

  在开发中遇到一个关于用户体验的问题,每次当运维进行更新重启服务器时,都会导致会员平台中已登录的用户掉线。这是因为每个用户的会话信息及状态都是由session来保存的,而session对象是由服务器创建,并把session的Id以cookie的形式发送给客户端浏览器的(每个会话都有一个单独的sessionID)。当这个对象超过一定时间没有被使用或者服务器重启时,对象就会被销毁,也就导致了用户掉线。

2.解决办法

  在解决问题过程中发现,只要记住了刚才用户的sessionID,重启服务器后仍使用原来的id,就不会掉线,也就是说要保证session不被改变才可以保持用户的登录状态。在这里使用了Spring Session Data Redis来实现session的共享(redis:高速缓存数据库),也就是说使用redis对session进行一个持久化操作(用mysql等数据库来单独存储session有点浪费了,速度也没有redis快),当服务器重启时,可以从redis中反序列化取出session,重新获取用户会话信息。

  简要配置步骤:

  (1)pom.xml加入依赖:spring-session-data-redis、spring-session,当然前提要有spring(4.3.5)、redis的依赖(redis使用了3.0版本)

  技术分享图片

  (2)applicationContext.xml配置文件中增加RedisHttpSessionConfiguration(下面是单独的配置文件,然后import进去)

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <beans xmlns="http://www.springframework.org/schema/beans"
 3        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 4        xmlns:p="http://www.springframework.org/schema/p"
 5        xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
 6     <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig" >
 7         <property name="maxIdle" value="0" />
 8         <property name="maxTotal" value="20" />
 9         <property name="maxWaitMillis" value="1000" />
10         <property name="testOnBorrow" value="true" />
11     </bean>
12 
13     <!-- redis连接配置,依次为主机ip,端口,是否使用池,(usePool=true时)redis的池配置 -->
14     <bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
15           p:host-name="0.0.0.0" p:port="1111" p:database="10" p:pool-config-ref="jedisPoolConfig">
16     </bean>
17 
18     <!-- 配置spring-session -->
19     <bean class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration">
20         <!-- 过期时间100分钟 -->
21         <property name="maxInactiveIntervalInSeconds" value="6000"></property>
22     </bean>
23 </beans>

  (3)web.xml中配置filter、session超时时间

  技术分享图片

  配置完成后,基本就可以实现Session的共享了,重启服务器测试,已经登录的用户也不会发生掉线的情况了。

最后贴几个参考链接:

session原理及实现共享

Spring Session Data Redis 配置中遇到的坑

集群/分布式环境下5种session处理策略

Spring Session Data Redis实现session共享

标签:href   mys   work   分布   创建   就是   targe   ica   cookie   

原文地址:https://www.cnblogs.com/jakeylove3/p/8475508.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!