前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【快学springboot】11.整合redis实现session共享

【快学springboot】11.整合redis实现session共享

作者头像
Happyjava
发布2019-07-16 17:57:44
4630
发布2019-07-16 17:57:44
举报
文章被收录于专栏:Happy的分享Happy的分享

前言

**这里都是基于前面的项目基础上的。**springboot整合redis非常的方便,这也是springboot的宗旨,简化配置。这篇文章就教大家如何使用springboot整合redis来实现session共享。

引入依赖

代码语言:javascript
复制
<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>
复制代码

配置redis

在application.properties中配置redis

代码语言:javascript
复制
# Redis服务器地址

spring.redis.host=localhost

# Redis服务器连接端口

spring.redis.port=6379

# Redis服务器连接密码(默认为空)

spring.redis.password=
复制代码

因为我本地redis没有设置密码,所以密码这里留空。这个配置项可以去掉,但是我留在这是是想告诉大家可以在这里配置redis密码

实现session共享

其实springboot实现session共享非常的方便,只需要一个@EnableRedisHttpSession注解即可。把该注解加在springboot启动类的上面。

到这里,已经实现redis存储session的功能了。下面通过一个简单例子测试下session是否存储在redis中了。

新建一个SessionController.java,并且写一个设置session的方法,如下:

启动项目,通过postman调用,如下:

通过redis可视化工具,查看redis中是否存在该属性:

通过查看,happyjava已经存在redis中了。

使用nginx测试

通过上面的例子,已经证明了session被redis存储了,下面,我们通过把应用启动在两个端口,使用nginx转发,测试session是否真的共享了。

nginx.config配置

代码语言:javascript
复制
upstream session_server {

server 127.0.0.1:8080;

server 127.0.0.1:8081;

}

server {

listen 80;

server_name localhost;

location / {

proxy_pass http://session_server;

proxy_set_header Host $host;

}

}
复制代码

这里把localhost这个请求,转发到了本地的8080和8081端口。

通过server.port指定程序的端口号

application.properties

代码语言:javascript
复制
server.port=8081
复制代码

写一个获取session的方法

SessionController.java

这里通过Value注解获取了配置文件的server.port属性,并且通过getSession方法返回。

把程序启动在两个端口

IDEA设置可以多次启动同个main方法。

把Allow paralled run勾上,即可多次启动一个main方法了。我们先把server.port设置为8080启动一次,然后改为8081再次启动。

通过postman多次调用,可以获得结果如下:

可以看到,port分别出现了8080和8081,并且都能够正常获取到之前设置的happyjava这个值,说明session共享已经配置成功了。

总结

springboot配置session共享是非常方便的,只需要EnableRedisHttpSession注解即可。其实也可以使用EnableMongoHttpSession注解用MongoDB来管理session。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年06月16日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 引入依赖
  • 配置redis
  • 实现session共享
  • 使用nginx测试
  • 通过server.port指定程序的端口号
  • 写一个获取session的方法
  • 把程序启动在两个端口
  • 总结
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档