Spring session實(shí)現(xiàn)Session共享
Redis session
用戶第一次訪問應(yīng)用,會創(chuàng)建一個(gè)新的Session,并且會將Session的ID作為Cookie緩存在瀏覽器。下一次訪問請求時(shí),請求的頭部會帶有Cookie。應(yīng)用通過Session ID進(jìn)行查找。如果Session存在并且有效,就會繼續(xù)請求。
為什么使用session共享:
如果沒有Session共享,session的信息放在內(nèi)存中,如果Tomcat關(guān)閉,內(nèi)存中的Session就會銷毀。在多實(shí)例(多個(gè)Tomcat)中無法共享,導(dǎo)致一個(gè)用戶只能訪問一個(gè)實(shí)例。
在實(shí)現(xiàn)共享后,只要Cookie中的Session ID 無法改變,多實(shí)例的任意一個(gè)被銷毀,都不會影響用戶訪問。
- 有了session共享,即使服務(wù)器重啟也不需要重新登錄。
- 假設(shè)某個(gè)網(wǎng)站是由多臺服務(wù)器提供服務(wù),nginx采用輪詢機(jī)制做負(fù)載均衡,那么同一個(gè)IP訪問該網(wǎng)站時(shí),請求就可能會被分配到不同的服務(wù)器上,如果 session 沒有 實(shí)現(xiàn)共享 ,就會出現(xiàn)重復(fù)登陸授權(quán)的情況。
- 注意,瀏覽器不能關(guān)閉,因?yàn)闉g覽器的cookie是會話級別的,瀏覽器關(guān)閉就會失效。
session 共享原理:
當(dāng)請求進(jìn)來的時(shí)候,SessionRepositoryFilter 會先攔截到請求,將 request 和 response 對象轉(zhuǎn)換成 SessionRepositoryRequestWrapper 和 SessionRepositoryResponseWrapper 。后續(xù)當(dāng)?shù)谝淮握{(diào)用 request 的getSession方法時(shí),會調(diào)用SessionRepositoryRequestWrapper 的getSession方法。這個(gè)方法是被重寫過的,邏輯是先從 request 的屬性中查找,如果找不到;再查找一個(gè)key值是"SESSION"的 Cookie,通過這個(gè) Cookie 拿到 SessionId 去 Redis 中查找,如果查不到,就直接創(chuàng)建一個(gè)RedisSession 對象,同步到 Redis 中。
說的簡單點(diǎn)就是:攔截請求,將之前在服務(wù)器內(nèi)存中進(jìn)行 Session 創(chuàng)建銷毀的動(dòng)作,改成在 Redis 中創(chuàng)建。
Spring Session提供了一套創(chuàng)建和管理Servlet HTTPSession的方案,Spring Session提供了集群Session功能,默認(rèn)采用外置的Redis來存儲Session數(shù)據(jù),以此來解決Session共享問題。
使用過濾器攔截請求
<!-- spring session共享filter --> <!-- 該過濾器必須是第一個(gè)過濾器,所有的請求經(jīng)過該過濾器后執(zhí)行后續(xù)操作 --> <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>
配置Redis
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" ? ? ? ?xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ? ? ? ?xsi:schemaLocation="http://www.springframework.org/schema/beans ? ? ? ? ? ? ? ? ? ? ? ? ?http://www.springframework.org/schema/beans/spring-beans.xsd"> ? ? <!--Jedis連接池的相關(guān)配置--> ? ? <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"> ? ? ? ? <!--最大連接數(shù), 默認(rèn)8個(gè)--> ? ? ? ? <property name="maxTotal" value="100"></property> ? ? ? ? <!--最大空閑連接數(shù), 默認(rèn)8個(gè)--> ? ? ? ? <property name="maxIdle" value="50"></property> ? ? ? ? <!--允許借調(diào) 在獲取連接的時(shí)候檢查有效性, 默認(rèn)false--> ? ? ? ? <property name="testOnBorrow" value="true"/> ? ? ? ? <!--允許歸還 在return給pool時(shí),是否提前進(jìn)行validate操作--> ? ? ? ? <property name="testOnReturn" value="true"/> ? ? </bean> ? ? <!--配置JedisConnectionFactory--> ? ? <bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"> ? ? ? ? <property name="hostName" value="192.168.175.100"/> ? ? ? ? <property name="port" value="6379"/> ? ? ? ? <property name="database" value="0"/> ? ? ? ? <property name="poolConfig" ref="jedisPoolConfig"/> ? ? </bean> ? ? <!-- 配置session共享 --> ? ? <bean id="redisHttpSessionConfiguration" ? ? ? ? ? class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration"> ? ? ? ? <property name="maxInactiveIntervalInSeconds" value="600" /> ? ? </bean> </beans>
到此這篇關(guān)于Spring session實(shí)現(xiàn)Session共享的文章就介紹到這了,更多相關(guān)Spring session 共享內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- spring boot整合redis實(shí)現(xiàn)shiro的分布式session共享的方法
- SpringBoot2.x 整合Spring-Session實(shí)現(xiàn)Session共享功能
- 詳解springboot中redis的使用和分布式session共享問題
- 利用Spring Session和redis對Session進(jìn)行共享詳解
- Springboot實(shí)現(xiàn)多服務(wù)器session共享
- Spring整合redis(jedis)實(shí)現(xiàn)Session共享的過程
- Spring boot集成spring session實(shí)現(xiàn)session共享的方法
- SpringSession+Redis實(shí)現(xiàn)集群會話共享的方法
- 基于SpringBoot+Redis的Session共享與單點(diǎn)登錄詳解
- spring boot與redis 實(shí)現(xiàn)session共享教程
- SpringBoot中實(shí)現(xiàn)分布式的Session共享的詳細(xì)教程
相關(guān)文章
在Spring中利用@Order注解對bean和依賴進(jìn)行排序
在Spring框架中,@Order是一個(gè)經(jīng)常被忽視但非常重要的注解,在項(xiàng)目開發(fā)中,當(dāng)我們需要維護(hù)bean的特定順序或者存在許多相同類型的bean時(shí),這個(gè)注解就發(fā)揮了作用,這篇文章講的就是如何利用@Order注解對bean和依賴進(jìn)行排序,需要的朋友可以參考下2023-11-11mybatis中關(guān)于mapper的使用以及注意事項(xiàng)
這篇文章主要介紹了mybatis中關(guān)于mapper的使用以及注意事項(xiàng),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06解決RestTemplate第一次請求響應(yīng)速度較慢的問題
這篇文章主要介紹了解決RestTemplate第一次請求響應(yīng)速度較慢的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10Java設(shè)計(jì)模式之抽象工廠模式(Abstract?Factory)
這篇文章主要為大家詳細(xì)介紹了Java設(shè)計(jì)模式之抽象工廠模式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03