Spring Boot 菜鸟教程 21 分布式会话

适用场景

  • 为了使Web能适应大规模的访问,需要实现应用程序的集群部署
  • 实现集群部署首先要解决session的统一,即需要实现session的共享机制,即分布式会话

分布式Session的实现方式

  • 基于resin/tomcat web容器本身的session复制机制
  • 基于NFS共享文件系统
  • 基于Cookie进行session共享
  • 基于数据库的Session共享
  • 基于分布式缓存的Session共享,如memcached,Redis,jbosscache
  • 基于ZooKeeper的Session共享

下面代码将演示基于Spring Session的实现,这个是基于Redis缓存的Session共享。

方案1

如果配置的Redis的是自己在维护,那很方便就可以实现了。

Spring Session官方文档

http://docs.spring.io/spring-session/docs/current/reference/html5/guides/boot.html

添加依赖

只需要在pom文件添加以下依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-redis</artifactId>
</dependency>

<dependency>
    <groupId>org.springframework.session</groupId>
    <artifactId>spring-session</artifactId>
</dependency>

启动类添加@EnableRedisHttpSession注解

配置文件application.properties

spring.redis.host=localhost
spring.redis.port=6379
server.session.timeout=36000

Spring Boot会自动把session从文件存储方式切换到Redis方式,根本不需要再做任何配置。


方案2

如果配置的Redis的不是自己在维护,不能够更改它的配置(如应用程序部署在阿里云,同时使用阿里云的Redis数据库),那就有点麻烦了。

额外功能

因为方案1需要Redis的一个功能:

notify-keyspace-events

默认情况下,这个功能是不开启的。

开启额外功能

如果你要使用方案1,你就必须通过下面的命令,来让你的Reids开启这个功能。

redis-cli config set notify-keyspace-events Egx

那就必须新建如下RedisSessionConfig类,即可在不改变Redis配置的前提下使用Redis来存储Session了。

RedisSessionConfig

package com.jege.spring.boot.Config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.session.data.redis.config.ConfigureRedisAction;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;

/**
 * @author JE哥
 * @email 1272434821@qq.com
 * @description:可在不改变Redis配置的前提下使用Redis来存储Session了
 */
@Configuration
//在这里设置Session过期时间,单位:秒
@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 36000)
public class RedisSessionConfig {
    @Bean
    public static ConfigureRedisAction configureRedisAction() {
        return ConfigureRedisAction.NO_OP;
    }
}

Spring Session默认会话时间

Spring Session默认的Session过期时间是30分钟。

采用方案1的时候,你可以在application.properties里配置

server.session.timeout=36000

来设置Session过期时间(单位是秒)。

如果采用方案2来配置Session,
那么application.properties里设置的Session过期时间是不起作用的。
必须使用上面RedisSessionConfig类里注解的参数来设置。

验证

需要使用nginx,配置2个tomcat来验证,需要等待。。。

其他关联项目

源码地址

https://github.com/je-ge/spring-boot

如果觉得我的文章或者代码对您有帮助,可以请我喝杯咖啡。
**您的支持将鼓励我继续创作!谢谢! **

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335

推荐阅读更多精彩内容