使用Spring boot基于Redis快速搭建分布式Session缓存方案
2017-12-07 11:24
1276 查看
使用Spring boot基于Redis快速搭建分布式Session缓存方案
大型web应用中,session的管理非常重要,这是单机存储满足不了的.通常有以下几种方法:
将session持久化到数据库中. 但缺点是读写成本太高.
去session化,比如将信息存储到cookie中. 但缺点是大小有限制,并且不安全.
3 . 将session存储到一个分布式的nosql数据库中,比如 Redis.
接下来就介绍一下 在SpringBoot应用中如何快速搭建一个基于Redis的分布式session存储方案
第一步:搭建Spring Boot开发环境
添加maven核心依赖 spring-session-data-redis<!--基于redis的分布式session存储--> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId> </dependency>
在application.properties文件中配置redis连接属性
###### Redis config start ###### spring.redis.database=0 spring.redis.host=192.168.41.60 spring.redis.port=6379 spring.redis.password= spring.redis.pool.max-active=20 spring.redis.pool.max-wait=-1 spring.redis.pool.max-idle=8 spring.redis.pool.min-idle=0 spring.redis.timeout=0 ###### Redis config end ######
第二步:开启 @EnableRedisHttpSession 注解
@Configuration @EnableRedisHttpSession(redisNamespace = "mysession",maxInactiveIntervalInSeconds = 60*60*24) public class SessionConfig { }
@EnableRedisHttpSession注解的源码如下,可以看到可以配置三个参数:
maxInactiveIntervalInSeconds :session中的数据的过期时间(不是session在redis中的过期时间)
redisNamespace :命名空间,可以配置当前应用的名称,我这里配置了 mysession.
redisFlushMode :redis保存session的方式,默认 ON_SAVE
有两种方式: IMMEDIATE:一旦创建session的时候就立即保存. ON_SAVE:创建session的时候不会保存,但当往session中添加数据的时候就会保存
@Retention(java.lang.annotation.RetentionPolicy.RUNTIME) @Target({ java.lang.annotation.ElementType.TYPE }) @Documented @Import(RedisHttpSessionConfiguration.class) @Configuration public @interface EnableRedisHttpSession { int maxInactiveIntervalInSeconds() default 1800; String redisNamespace() default ""; RedisFlushMode redisFlushMode() default RedisFlushMode.ON_SAVE; }
第三步:测试
编写一个controller@RestController public class HelloController { @RequestMapping("/hello/{username}") public String hello(HttpSession session, @PathVariable(value = "username") String username) { session.setAttribute("username", username); return "保存session到Redis成功"; } @RequestMapping("/getName") public String getUsername(HttpSession session) { String username = (String) session.getAttribute("username"); return username; } }
当浏览器访问 http://localhost:8080/hello/admin 这个链接,
hello方法会接受到 浏览器传过来的参数,并保存在session中,然后再把session保存到Redis中
通过查看redis中的信息可看到如下信息:
其中 spring:session 是自动添加的,我们创建的命名空间 mysession 在这个默认的目录下面
接下来我们再访问 http://localhost:8080/getName ,便可以看到浏览器会显示 刚才我们保存再session中的 admin
小结:
上面结合示例代码介绍了数据缓存,共享Session两个Redis的典型应用场景.除此之外,还有分布式锁,全局计数器等高级应用场景,以后在其他文章中再详细介绍.
源码地址:https://github.com/itguang/redis-session
相关文章推荐
- Spring Boot 基于注解的 Redis 缓存使用详解
- 基于springboot+bootstrap+mysql+redis搭建一套完整的权限架构【五】【编写基础代码快速生成工具】
- Spring Boot 基于注解的 Redis 缓存使用
- [置顶] 在Springboot上使用jedis来操作缓存redis --jedis的配置
- 基于Spring Boot-Spring Session-Redis的分布式Session共享解决方案
- Spring Boot中使用Redis做缓存的方法实例
- Spring Boot中的缓存支持(二)使用Redis做集中式缓存
- SpringBoot中搭建Redis缓存功能
- spring-redis缓存方案学习三:基于aop的自定义注解开发
- Redis系列三 - Spring boot如何使用redis做缓存及缓存注解的用法总结
- 使用SpringBoot快速搭建服务器
- SpringBoot集成Redis来实现缓存技术方案
- spring boot 快速搭建 基于 Restful 风格的微服务
- Spring Boot中的缓存支持(二)使用Redis做集中式缓存
- 详解Spring boot使用Redis集群替换mybatis二级缓存
- Spring Boot使用redis做数据缓存
- springboot学习1-使用 Spring Starter Project快速创建基于spring-boot的web项目
- Spring Boot使用redis做数据缓存
- 3 Springboot中使用redis,redis自动缓存异常处理
- 使用Springboot快速搭建项目