1. 程式人生 > >Spring Session Data Redis實現session共享

Spring Session Data Redis實現session共享

web.xml odi 數據庫 tails spool ima 配置步驟 配置文件 work

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共享