springboot集成springsession如何实现分布式session共享

 更新时间:2023年09月21日 09:15:30   作者:爱琴孩  
这篇文章主要介绍了springboot集成springsession如何实现分布式session共享问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

前言

现在随着分布式,微服务架构的日益成熟,越来越多的企业将传统的单体服务改造成微服务或者分布式架构。

当然不是说单体服务现在是百无一用,只能说没有最好的,只要适合就好。

在分布式服务改造中,大家都遇到过一个问题,那就是分布式session管理。

之前的单体服务session是保存在容器的内存中的。

微服务架构中一个服务为了实现高可用都是至少3个点部署,这样就遇到一个问题,就是这个部署在不同服务器上的三个点如何实现共享session呢?

其实解决方案是很多的,原理也是差不多的。比如说我们现在项目就是将session保存在数据库中,这样三个点都去读取数据库来实现session共享。

还有的方案就是大家比较熟悉的将session存储在redis中,而且redis支持key设置过期时间,这个和用户会话的过期就不谋而合了。

只不过传统的集成方案需要我们手动的将session存储在redis中,然后再在redis中读取,这种方式操作起来可能比较重复繁琐。

所以spring已经在spring全家桶中提供了分布式session共享集成方案,就是标题中所说的springsession。

这里基于springboot来搭建个入门demo,以便大家快速了解springsession。

集成springsession之前

这里简单搭建了两个服务client1和cilent2,我们在这连个服务中提供两个接口,如下

/**
 * @author 蒋墨风
 * @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代码是一样的,这里就不重复粘贴了。

两个服务的端口分别是9002和9003。这里我们把两个服务启动成功之后,我们先访问client1的test接口,然后在访问client1中sessions接口来看下具体session打印。

client1中的sessions接口响应如下

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

接下来我们依次访问client2接口中的test接口和sessions接口,得到的响应如下

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

可以看到两个session是相互独立的。

集成springsession之后

首先我们在两个服务中引入相关的依赖

<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

再在两个服务的启动类上加上@EnableRedisHttpSession注解,开启spring session功能,两个服务正常启动之后,重复上面操作,先访问client1的test和sessions接口,接口响应如下

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

接下来我们再访问client2服务中的test,sessions接口,接口响应如下

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

可以看到两个sessionId是一样的,所以client1和client2的共享session是实现了的,网上好多小伙伴说,你这种实现方式是两个服务部署在同一台机器上,如果把两个服务分别部署在两台机器上,上面的测试效果就不是这样了,如果遇到这种情况的小伙伴可能需要确认下自己测试的两台机器上的时间是不是一致,如果不是的话,就可能会导致上面的测试失败。

总结

上面只是简单的演示了下两个服务集成springsession之前和之后的效果,具体springsession的原理,后面结合springsession源码来和大家一起学习,这里springsession集成了redis,用redis做session存储,当然我们也可以使用其他的存储,不局限于redis。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java多线程优化方法及使用方式

    Java多线程优化方法及使用方式

    这篇文章主要介绍了Java多线程优化方法及使用方式,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-02-02
  • 全网最精细详解二叉树,2万字带你进入算法领域

    全网最精细详解二叉树,2万字带你进入算法领域

    大家好,我是哪吒,一个热爱编码的Java工程师,本着"欲速则不达,欲达则欲速"的学习态度,在程序猿这条不归路上不断成长,所谓成长,不过是用时间慢慢擦亮你的眼睛,少时看重的,年长后却视若鸿毛,少时看轻的,年长后却视若泰山,成长之路,亦是渐渐放下执念,内心归于平静的旅程
    2021-08-08
  • Java实现滑块拼图验证码

    Java实现滑块拼图验证码

    这篇文章主要为大家详细介绍了Java实现滑块拼图验证码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • 一文搞懂 MyBatis的事务管理机制

    一文搞懂 MyBatis的事务管理机制

    MyBatis是一款优秀的持久层框架,相信很多Java后端开发人员对它都不会陌生。本文将从事务概述、MyBatis实现事务的方式、事务实现源码分析方面详细解析MyBatis的事务管理机制,需要的朋友可以参考下
    2023-05-05
  • Java线程状态运行原理解析

    Java线程状态运行原理解析

    这篇文章主要介绍了Java线程状态运行原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • Spring Boot 把配置文件和日志文件放到jar外部

    Spring Boot 把配置文件和日志文件放到jar外部

    如果不想使用默认的application.properties,而想将属性文件放到jar包外面,怎么做呢?下面小编给大家带来了两种方法解决Spring Boot 把配置文件和日志文件放到jar外部问题,感兴趣的朋友一起看看吧
    2018-02-02
  • activemq整合springboot使用方法(个人微信小程序用)

    activemq整合springboot使用方法(个人微信小程序用)

    这篇文章主要介绍了activemq整合springboot使用(个人微信小程序用),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • 在CentOS系统上安装Java JDK 8简单步骤

    在CentOS系统上安装Java JDK 8简单步骤

    最近购买一台新的云服务器,用于开发学习使用,因此需要安装很多的组件,下面这篇文章主要给大家介绍了关于在CentOS系统上安装Java JDK8的简单步骤,需要的朋友可以参考下
    2023-12-12
  • Java 如何实现POST(x-www-form-urlencoded)请求

    Java 如何实现POST(x-www-form-urlencoded)请求

    这篇文章主要介绍了Java 实现POST(x-www-form-urlencoded)请求,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-10-10
  • String转double失去精度问题及解决

    String转double失去精度问题及解决

    这篇文章主要介绍了关于String转double失去精度问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07

最新评论