欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot集成springsession如何實(shí)現(xiàn)分布式session共享

 更新時(shí)間:2023年09月21日 09:15:30   作者:愛琴孩  
這篇文章主要介紹了springboot集成springsession如何實(shí)現(xiàn)分布式session共享問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

前言

現(xiàn)在隨著分布式,微服務(wù)架構(gòu)的日益成熟,越來越多的企業(yè)將傳統(tǒng)的單體服務(wù)改造成微服務(wù)或者分布式架構(gòu)。

當(dāng)然不是說單體服務(wù)現(xiàn)在是百無一用,只能說沒有最好的,只要適合就好。

在分布式服務(wù)改造中,大家都遇到過一個(gè)問題,那就是分布式session管理。

之前的單體服務(wù)session是保存在容器的內(nèi)存中的。

微服務(wù)架構(gòu)中一個(gè)服務(wù)為了實(shí)現(xiàn)高可用都是至少3個(gè)點(diǎn)部署,這樣就遇到一個(gè)問題,就是這個(gè)部署在不同服務(wù)器上的三個(gè)點(diǎn)如何實(shí)現(xiàn)共享session呢?

其實(shí)解決方案是很多的,原理也是差不多的。比如說我們現(xiàn)在項(xiàng)目就是將session保存在數(shù)據(jù)庫中,這樣三個(gè)點(diǎn)都去讀取數(shù)據(jù)庫來實(shí)現(xiàn)session共享。

還有的方案就是大家比較熟悉的將session存儲在redis中,而且redis支持key設(shè)置過期時(shí)間,這個(gè)和用戶會話的過期就不謀而合了。

只不過傳統(tǒng)的集成方案需要我們手動的將session存儲在redis中,然后再在redis中讀取,這種方式操作起來可能比較重復(fù)繁瑣。

所以spring已經(jīng)在spring全家桶中提供了分布式session共享集成方案,就是標(biāo)題中所說的springsession。

這里基于springboot來搭建個(gè)入門demo,以便大家快速了解springsession。

集成springsession之前

這里簡單搭建了兩個(gè)服務(wù)client1和cilent2,我們在這連個(gè)服務(wù)中提供兩個(gè)接口,如下

/**
 * @author 蔣墨風(fēng)
 * @title: SpringSessionController
 * @projectName client1
 * @description: 測試spring session功能
 * @date 2019/10/27 16:11
 */
@RequestMapping("/springSessionTest")
@RestController
public class SpringSessionController {
    @RequestMapping(value = "/test", method = RequestMethod.GET)
    public Map<String, Object> firstResp (HttpServletRequest request){
        Map<String, Object> map = new HashMap<>();
        request.getSession().setAttribute("request Url", request.getRequestURL());
        map.put("request Url", request.getRequestURL());
        return map;
    }
    @RequestMapping(value = "/sessions", method = RequestMethod.GET)
    public Object sessions (HttpServletRequest request){
        Map<String, Object> map = new HashMap<>();
        map.put("sessionId", request.getSession().getId());
        map.put("message", request.getSession().getAttribute("request Url"));
        return map;
    }
}

client2中的接口和client1代碼是一樣的,這里就不重復(fù)粘貼了。

兩個(gè)服務(wù)的端口分別是9002和9003。這里我們把兩個(gè)服務(wù)啟動成功之后,我們先訪問client1的test接口,然后在訪問client1中sessions接口來看下具體session打印。

client1中的sessions接口響應(yīng)如下

{
"sessionId":"6C3E8502E1DFA9FB5595D8EEE848A900",
"message":"http://localhost:9002/springSessionTest/test"
}

接下來我們依次訪問client2接口中的test接口和sessions接口,得到的響應(yīng)如下

{
"sessionId":"B6DEB7D49CCA3AA239FA593555605C4B",
"message":"http://localhost:9003/springSessionTest/test"
}

可以看到兩個(gè)session是相互獨(dú)立的。

集成springsession之后

首先我們在兩個(gè)服務(wù)中引入相關(guān)的依賴

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.session</groupId>
    <artifactId>spring-session-data-redis</artifactId>
</dependency>
<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
 </dependency>

然后在配置文件中加上redis配置

spring.redis.host=127.0.0.1
spring.redis.port=6379
spring.redis.database=3
spring.redis.password=12345
spring.redis.timeout=5000

再在兩個(gè)服務(wù)的啟動類上加上@EnableRedisHttpSession注解,開啟spring session功能,兩個(gè)服務(wù)正常啟動之后,重復(fù)上面操作,先訪問client1的test和sessions接口,接口響應(yīng)如下

{
"sessionId":"5fdd9b56-70ab-4722-81f6-8c4af721a1e6",
"message":"http://localhost:9002/springSessionTest/test"
}

接下來我們再訪問client2服務(wù)中的test,sessions接口,接口響應(yīng)如下

{
"sessionId":"5fdd9b56-70ab-4722-81f6-8c4af721a1e6",
"message":"http://localhost:9003/springSessionTest/test"
}

可以看到兩個(gè)sessionId是一樣的,所以client1和client2的共享session是實(shí)現(xiàn)了的,網(wǎng)上好多小伙伴說,你這種實(shí)現(xiàn)方式是兩個(gè)服務(wù)部署在同一臺機(jī)器上,如果把兩個(gè)服務(wù)分別部署在兩臺機(jī)器上,上面的測試效果就不是這樣了,如果遇到這種情況的小伙伴可能需要確認(rèn)下自己測試的兩臺機(jī)器上的時(shí)間是不是一致,如果不是的話,就可能會導(dǎo)致上面的測試失敗。

總結(jié)

上面只是簡單的演示了下兩個(gè)服務(wù)集成springsession之前和之后的效果,具體springsession的原理,后面結(jié)合springsession源碼來和大家一起學(xué)習(xí),這里springsession集成了redis,用redis做session存儲,當(dāng)然我們也可以使用其他的存儲,不局限于redis。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論