mysql集群session_集群session解决方案

集群状态下的session解决方法

在集群的环境下,请求可能会被转发到不同的服务器上去处理,这样会导致,在服务器A上等以后,处理其他任务时被分配到服务器B上,此时服务器A上session不存在在服务器B上,会让用户重新登录,这样的体验用户肯定不能接受。

解决方案

session复制(如果集群环境过大,也不推荐)

session共享

保存在cookie中(不推荐)

本次使用session共享的方式解决

测试环境:spring boot +redis

测试工具 chrome浏览器

开发工具 idea

项目构建工具maven

1:首先创建springboot项目

org.springframework.boot

spring-boot-starter-data-redis

org.springframework.boot

spring-boot-starter-web

org.springframework.session

spring-session-core

org.springframework.session

spring-session-data-redis

org.springframework.boot

spring-boot-starter-test

test

org.junit.vintage

junit-vintage-engine

@GetMapping("/get")publicString index(HttpServletRequest request) {

Object name= request.getSession().getAttribute("name");return name != null ? "success" : "false";

}

@GetMapping("/set")publicString index(HttpServletRequest request,HttpServletResponse response){

Object name= request.getSession().getAttribute("name");if (null==name)

request.getSession().setAttribute("name", "zs");return "set success";

}

运行了两个springboot项目,一个在端口8080,一个在端口8081,模拟集群环境

0d850dcfd29a9e44cb16ad0aebf01024.png

659c732a5e0c82e874eac142049fdd7d.png

8080,8081两个端口的项目访问都是false,说明此时没有session

58ae65897d47fe1e1cc2232c783049db.png

此时手动设置一个session值后,再次访问get,返回success

102f95816165520712c6abe4ff44c450.png

访问8081端口的项目

b347453acd76b8b98fc146161db3c223.png

返回success,说明成功获取到session

f5c4212824b45126e372b7ff70044d40.png

redis中存在刚才存入的session值,说明集群获取session成功。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值