利用spring-session實現session共享

1、添加依賴包(項目使用spring版本3.2.12.RELEASE)

<dependency>
	        <groupId>org.springframework.data</groupId>
	        <artifactId>spring-data-redis</artifactId> 
	         <version>1.5.2.RELEASE</version>
	    </dependency>
	    <dependency> 
	        <groupId>redis.clients</groupId>
	        <artifactId>jedis</artifactId>
	        <version>2.4.2</version>
	    </dependency>
	    <dependency>
		    <groupId>org.springframework.session</groupId>
		    <artifactId>spring-session</artifactId>
		    <version>1.2.0.RELEASE</version>
		</dependency>
		<dependency>
		    <groupId>org.apache.commons</groupId>
		    <artifactId>commons-pool2</artifactId>
		    <version>2.2</version>
		</dependency>

2、web.xml添加過濾器

<!-- web.xml -->  
<filter>  
    <filter-name>springSessionRepositoryFilter</filter-name>
    <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>  
<filter-mapping>  
    <filter-name>springSessionRepositoryFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

注意:該過濾器須要添加到全部過濾器的最前面html

3、在applicationContext.xml中添加配置

<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
	</bean>
	 
	<bean id="jedisConnectionFactory"
	    class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
	    <property name="hostName" value="${redis.host}" />
	    <property name="port" value="${redis.port}" />
	  <!--   <property name="password" value="${redis.pass}" /> -->
	    <property name="timeout" value="${redis.timeout}" />
	    <property name="poolConfig" ref="jedisPoolConfig" />
	    <property name="usePool" value="true" />
	</bean>
	 
	<bean id="redisTemplate" class="org.springframework.data.redis.core.StringRedisTemplate">
	    <property name="connectionFactory" ref="jedisConnectionFactory" />
	</bean>
	 
	<!-- 將session放入redis,過時時間1天-->
	<bean id="redisHttpSessionConfiguration"
	class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration">
	    <property name="maxInactiveIntervalInSeconds" value="86400" />
	</bean>

4、如何在Redis中查看Session數據

一、Http Session數據在Redis中是以Hash結構存儲的。java

二、能夠看到,還有一個key="spring:session:expirations:1431577740000"的數據,是以Set結構保存的。這個值記錄了全部session數據應該被刪除的時間(即最新的一個session數據過時的時間)。web

127.0.0.1:6379> keys *  
1) "spring:session:expirations:1431577740000"  
2) "spring:session:sessions:e2cef3ae-c8ea-4346-ba6b-9b3b26eee578"  
127.0.0.1:6379> type spring:session:sessions:e2cef3ae-c8ea-4346-ba6b-9b3b26eee578  
hash  
127.0.0.1:6379> type spring:session:expirations:1431577740000  
set
127.0.0.1:6379> keys *  
1) "spring:session:expirations:1431527520000"  
2) "spring:session:sessions:59f3987c-d1e4-44b3-a83a-32079942888b"  
3) "spring:session:sessions:11a69da6-138b-42bc-9916-60ae78aa55aa"  
4) "spring:session:sessions:0a51e2c2-4a3b-4986-a754-d886d8a5d42d"  
5) "spring:session:expirations:1431527460000"  
  
127.0.0.1:6379> hkeys spring:session:sessions:59f3987c-d1e4-44b3-a83a-32079942888b  
1) "maxInactiveInterval"  
2) "creationTime"  
3) "lastAccessedTime"  
4) "sessionAttr:attr1"  
  
127.0.0.1:6379> hget spring:session:sessions:59f3987c-d1e4-44b3-a83a-32079942888b sessionAttr:attr1  
"\xac\xed\x00\x05sr\x00\x11java.lang.Integer\x12\xe2\xa0\xa4\xf7\x81\x878\x02\x00\x01I\x00\x05valuexr\x00\x10java.lang.Number\x86\xac\x95\x1d\x0b\x94\xe0\x8b\x02\x00\x00xp\x00\x00\x00\x03"  
  
127.0.0.1:6379> hget spring:session:sessions:59f3987c-d1e4-44b3-a83a-32079942888b creationTime  
"\xac\xed\x00\x05sr\x00\x0ejava.lang.Long;\x8b\xe4\x90\xcc\x8f#\xdf\x02\x00\x01J\x00\x05valuexr\x00\x10java.lang.Number\x86\xac\x95\x1d\x0b\x94\xe0\x8b\x02\x00\x00xp\x00\x00\x01MM\x94(\xec"

5、總結

Spring Session爲企業級Java的session管理帶來了革新,使得以下的任務變得更加容易:redis

一、編寫可水平擴展的原生雲應用。spring

二、將session所保存的狀態卸載到特定的外部session存儲中,如Redis或Apache Geode中,它們可以以獨立於應用服務器的方式提供高質量的集羣。apache

三、當用戶使用WebSocket發送請求的時候,可以保持HttpSession處於活躍狀態。瀏覽器

四、在非Web請求的處理代碼中,可以訪問session數據,好比在JMS消息的處理代碼中。服務器

五、支持每一個瀏覽器上使用多個session,這樣就能夠很容易地構建更加豐富的終端用戶體驗。cookie

六、控制客戶端和服務器端之間如何進行session id的交換,這樣更加易於編寫Restful API,由於它能夠從HTTP 頭信息中獲取session id,而沒必要再依賴於cookie。session

若是你想拋棄傳統的重量級應用服務器,但受制於已經使用了這些應用服務器的session集羣特性,那麼Spring Session將是幫助你邁向更加輕量級容器的重要一步,這些輕量級的容器包括Tomcat、Jetty或Undertow。

參考網址:

一、http://blog.csdn.net/wwd0501/article/details/51484671

二、http://blog.csdn.net/patrickyoung6625/article/details/45694157

三、http://docs.spring.io/spring-data/data-redis/docs/current/reference/html/

相關文章
相關標籤/搜索