SpringBoot利用Redis管理分布式Session

前言

由于Http连接是无状态的,所以使用Tomcat做服务器的时候Tomcat内部会维护一个叫做Session的东东用来保存客户端的状态,一般情况下每个客户端都有一个cookie里面保存着叫jsessionid的cookie,每次访问tomcat的时候都会携带上,Tomcat可以根据这个jsessionid找到对应的session。就像你去超市买东西,门口的储物柜可以视作一个session容器,而打出的二维码条就是cookie。
在分布式系统中,对于同一个客户端,访问哪个Tomcat服务器就会在哪个Tomcat里面创建session。简单来说我做一个登录功能,即第一次访问Tomcat的时候需要输入用户名密码,访问成功后就在自己的sesison里面写入用户名,那么我下次访问的时候直接检测session里是否有自己的用户名来判断自己是否处于登录状态了。现在问题来了,如果我第一次访问的是TomcatA,登录成功后由于nginx的负载均衡第二次访问打到了TomcatB上,那么TomcatB里面并没有我的用户名信息,所以我还需要重新登录。一个最直观的想法就是把TomcatA和TomcatB的session抽出来放到某一个位置,这样不管访问TomcatA还是TomcatB都会从同一个Session里面获取用户信息。
SpringBoot以一个非常简洁易用的方式帮我们实现了分布式Session,我们需要做的仅仅是1个注解,几行配置,几行代码。

一、配置maven

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

二、配置application.yml

spring:
  session:
    store-type: redis
    timeout: 3600s
    redis:
      flush-mode: on_save
      namespace: spring:session
  redis:
    host: 192.168.99.100
    port: 6379
    timeout: 5000ms

三、使用

//主类首先开启EnableRedisHttpSession注解
@SpringBootApplication
@EnableRedisHttpSession
public class DistributeSessionApplication {

    public static void main(String[] args) {
        SpringApplication.run(DistributeSessionApplication.class, args);
    }
}

四:经@Leododo提醒,已经去掉原来的测试方法

五、原理浅析

本质上利用Tomcat的Filter的实现类SpringSessionRepositoryFilter实现了对每一次请求的拦截,拦截之后把Session放到Redis里面

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,620评论 11 349
  • 目录Cookie机制什么是CookieCookie的不可跨域名性Unicode编码:保存中文BASE64编码:保存...
    Tomatoro阅读 17,033评论 7 186
  • 会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话。常用的会话跟踪技术是Cookie与Se...
    chinariver阅读 5,765评论 1 49
  • UIImageView图片拉伸(contentMode) UIViewContentModeScaleToFill...
    zhong_JF阅读 969评论 0 0
  • 四点左右,电闪雷鸣,大雨倾盆之下。六点起床,水流从东流至西街道上的水能没过小腿,给出行的人们带来很多不变。为...
    丽娜_550e阅读 299评论 1 2

友情链接更多精彩内容