Spring Session Data Redis實現session共享


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版本)

 1 <dependency>
 2     <groupId>org.springframework.session</groupId>
 3     <artifactId>spring-session-data-redis</artifactId>
 4     <version>1.3.2.RELEASE</version>
 5 </dependency>
 6 <dependency>
 7     <groupId>org.springframework.session</groupId>
 8     <artifactId>spring-session</artifactId>
 9     <version>1.3.2.RELEASE</version>
10 </dependency>

  (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超時時間

 1 <filter>
 2     <filter-name>springSessionRepositoryFilter</filter-name>
 3     <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
 4 </filter>
 5 <filter-mapping>
 6     <filter-name>springSessionRepositoryFilter</filter-name>
 7     <url-pattern>/*</url-pattern>
 8 </filter-mapping>
 9 <session-config>
10     <!--60*60*24-->
11     <session-timeout>86400</session-timeout>
12 </session-config>

  配置完成后,基本就可以實現Session的共享了,重啟服務器測試,已經登錄的用戶也不會發生掉線的情況了。

最后貼幾個參考鏈接:

session原理及實現共享

Spring Session Data Redis 配置中遇到的坑

集群/分布式環境下5種session處理策略


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM