詳解基于Spring Boot/Spring Session/Redis的分布式Session共享解決方案
分布式Web網(wǎng)站一般都會(huì)碰到集群session共享問題,之前也做過一些Spring3的項(xiàng)目,當(dāng)時(shí)解決這個(gè)問題做過兩種方案,一是利用nginx,session交給nginx控制,但是這個(gè)需要額外工作較多;還有一種是利用一些tomcat上的插件,修改tomcat配置文件,讓tomcat自己去把Session放到Redis/Memcached/DB中去。這兩種各有優(yōu)缺,也都能解決問題。
但是現(xiàn)在項(xiàng)目全線Spring Boot,并不自己維護(hù)Tomcat,而是由Spring去啟動(dòng)Tomcat。這樣就會(huì)有一個(gè)問題:在服務(wù)器上并不存在一個(gè)持久存在的Tomcat程序,這樣也無從去修改Tomcat的配置文件了。經(jīng)過了一番搜索,發(fā)現(xiàn)Spring果然對(duì)這個(gè)問題有自己的解決方案,那就是Spring-Session.
Spring-Session是通過過濾器實(shí)現(xiàn)的session共享,具體原理可以自己去官網(wǎng)查,這里只說一下如何配置。整個(gè)項(xiàng)目基于Spring Boot,如果不是Boot項(xiàng)目就需要自己去調(diào)整了。
項(xiàng)目需要先準(zhǔn)備一個(gè)Redis服務(wù),在本地啟動(dòng)一個(gè)即可。還需要有一個(gè)已經(jīng)使用session但是未做session共享的Spring Boot項(xiàng)目,下面我就講述一下如何給這個(gè)項(xiàng)目加上基于redis的session共享。
引入依賴
首先,要在maven中加入以下依賴:
<dependencies> <!-- ... --> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session</artifactId> <version>1.2.2.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-redis</artifactId> </dependency> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId> <version>1.2.2.RELEASE</version> <type>pom</type> </dependency> </dependencies>
這些就是Spring-Session和Redis相關(guān)的依賴。
配置Redis
在項(xiàng)目目前在使用的properties文件中,加入如下配置:
spring.redis.host=localhost spring.redis.password=secret spring.redis.port=6379
host就是redis地址,password為密碼,port為端口號(hào)。
Spring配置
在項(xiàng)目的目錄中,創(chuàng)建一個(gè)Config.java文件(名稱隨意)
@Configuration @EnableRedisHttpSession public class Config { @Bean public JedisConnectionFactory connectionFactory() { return new JedisConnectionFactory(); } }
@EnableRedisHttpSession這個(gè)注解就是最重要的東西,加了它之后,spring生產(chǎn)一個(gè)新的攔截器,用來實(shí)現(xiàn)Session共享的操作,具體實(shí)現(xiàn)這里暫不展開。而配置的這個(gè)Bean,則是讓Spring根據(jù)配置文件中的配置連到Redis。
如果不使用Security,下面的幾步就不用做了,這個(gè)類中配置的Bean也不用配置。
Spring Security 配置
在項(xiàng)目中添加該類:
public class SecurityInitializer extends AbstractSecurityWebApplicationInitializer { public SecurityInitializer() { super(SecurityConfig.class, Config.class); } }
super()的第二個(gè)參數(shù),就是我們上面的那個(gè)Config文件。添加這個(gè)配置文件后,Spring Security就會(huì)把Session放到Redis中,這樣基于Spring Security的項(xiàng)目也可以實(shí)現(xiàn)Session共享了。
Initializer 配置
這一步寫法異常簡(jiǎn)單,還是創(chuàng)建文件:
public class Initializer extends AbstractHttpSessionApplicationInitializer {}
就這樣,繼承一個(gè)類即可。
大功告成!簡(jiǎn)單的超乎想像,這就是Spring Boot的優(yōu)勢(shì)所在。下面我們來自己登錄一下,看看Spring Security是否把Session放到Redis中。
(登錄過程我就不講了,,在自己項(xiàng)目中調(diào)用一下Security的登錄即可)
然后用redis-cli連接到redis,執(zhí)行keys *
會(huì)看到如下:
你會(huì)發(fā)現(xiàn)redis里多了一堆以spring:session:***為key的東西,這樣就說明Spring Security確實(shí)把Session放到了我們配置的redis中。這樣就可以實(shí)現(xiàn)session共享了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java使用fastjson對(duì)String、JSONObject、JSONArray相互轉(zhuǎn)換
這篇文章主要介紹了Java使用fastjson對(duì)String、JSONObject、JSONArray相互轉(zhuǎn)換,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11Java SpringMVC實(shí)現(xiàn)PC端網(wǎng)頁微信掃碼支付(完整版)
這篇文章主要介紹了Java SpringMVC實(shí)現(xiàn)PC端網(wǎng)頁微信掃碼支付(完整版)的相關(guān)資料,非常不錯(cuò)具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2016-11-11java實(shí)現(xiàn)對(duì)excel文件的處理合并單元格的操作
這篇文章主要介紹了java實(shí)現(xiàn)對(duì)excel文件的處理合并單元格的操作,開頭給大家介紹了依賴引入代碼,表格操作的核心代碼,代碼超級(jí)簡(jiǎn)單,需要的朋友可以參考下2021-07-07Spring中基于Java的配置@Configuration和@Bean用法詳解
這篇文章主要介紹了Spring中基于Java的配置@Configuration和@Bean用法詳解,Spring中為了減少xml中配置,可以聲明一個(gè)配置類(例如SpringConfig)來對(duì)bean進(jìn)行配置。,需要的朋友可以參考下2019-06-06SpringBoot啟動(dòng)嵌入式Tomcat的實(shí)現(xiàn)步驟
本文主要介紹了淺談SpringBoot如何啟動(dòng)嵌入式Tomcat,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08Java中創(chuàng)建對(duì)象的5種方式總結(jié)
本篇文章主要介紹了Java中創(chuàng)建對(duì)象的5種方式總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02