日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

使用Spring Session做分布式会话管理

發(fā)布時間:2025/3/19 javascript 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用Spring Session做分布式会话管理 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

在Web項目開發(fā)中,會話管理是一個很重要的部分,用于存儲與用戶相關(guān)的數(shù)據(jù)。通常是由符合session規(guī)范的容器來負(fù)責(zé)存儲管理,也就是一旦容器關(guān)閉,重啟會導(dǎo)致會話失效。因此打造一個高可用性的系統(tǒng),必須將session管理從容器中獨立出來。而這實現(xiàn)方案有很多種,下面簡單介紹下:

  第一種是使用容器擴展來實現(xiàn),大家比較容易接受的是通過容器插件來實現(xiàn),比如基于Tomcat的tomcat-redis-session-manager,基于Jetty的jetty-session-redis等等。好處是對項目來說是透明的,無需改動代碼。不過前者目前還不支持Tomcat 8,或者說不太完善。個人覺得由于過于依賴容器,一旦容器升級或者更換意味著又得從新來過。并且代碼不在項目中,對開發(fā)者來說維護也是個問題。

  第二種是自己寫一套會話管理的工具類,包括Session管理和Cookie管理,在需要使用會話的時候都從自己的工具類中獲取,而工具類后端存儲可以放到Redis中。很顯然這個方案靈活性最大,但開發(fā)需要一些額外的時間。并且系統(tǒng)中存在兩套Session方案,很容易弄錯而導(dǎo)致取不到數(shù)據(jù)。

  第三種是使用框架的會話管理工具,也就是本文要說的spring-session,可以理解是替換了Servlet那一套會話管理,既不依賴容器,又不需要改動代碼,并且是用了spring-data-redis那一套連接池,可以說是最完美的解決方案。當(dāng)然,前提是項目要使用Spring Framework才行。

  這里簡單記錄下整合的過程:

  如果項目之前沒有整合過spring-data-redis的話,這一步需要先做,在maven中添加這兩個依賴:

<dependency> ????<groupId>org.springframework.data</groupId> ????<artifactId>spring-data-redis</artifactId> ????<version>1.5.2.RELEASE</version> </dependency> <dependency> ????<groupId>org.springframework.session</groupId> ????<artifactId>spring-session</artifactId> ????<version>1.0.2.RELEASE</version> </dependency>

  再在applicationContext.xml中添加以下bean,用于定義redis的連接池和初始化redis模版操作類,自行替換其中的相關(guān)變量。

<!-- redis --> <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 --> <bean id="redisHttpSessionConfiguration" class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration"> ????<property name="maxInactiveIntervalInSeconds" value="1800" /> </bean>

  這里前面幾個bean都是操作redis時候使用的,最后一個bean才是spring-session需要用到的,其中的id可以不寫或者保持不變,這也是一個約定優(yōu)先配置的體現(xiàn)。這個bean中又會自動產(chǎn)生多個bean,用于相關(guān)操作,極大的簡化了我們的配置項。其中有個比較重要的是springSessionRepositoryFilter,它將在下面的代理filter中被調(diào)用到。maxInactiveIntervalInSeconds表示超時時間,默認(rèn)是1800秒。寫上述配置的時候我個人習(xí)慣采用xml來定義,官方文檔中有采用注解來聲明一個配置類。

  然后是在web.xml中添加一個session代理filter,通過這個filter來包裝Servlet的getSession()。需要注意的是這個filter需要放在所有filter鏈最前面。

<!-- delegatingFilterProxy --> <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>

  這樣便配置完畢了,需要注意的是,spring-session要求Redis Server版本不低于2.8。

  驗證:使用redis-cli就可以查看到session key了,且瀏覽器Cookie中的jsessionid已經(jīng)替換為session。

127.0.0.1:6379> KEYS * 1) "spring:session:expirations:1440922740000" 2) "spring:session:sessions:35b48cb4-62f8-440c-afac-9c7e3cfe98d3"

總結(jié)

以上是生活随笔為你收集整理的使用Spring Session做分布式会话管理的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。