如何搭建有状态的集群web服务

1 篇文章 0 订阅
1 篇文章 0 订阅

1、目的:为了高可用,需要搭建两个web容器构成集群(比如两个tomcat 、两个nginx),并且需要用户无感知(即会话需要共享)

2、解决方案:

        2.1 会话信息不能采用j2ee自带的session变量来存储,采用redis来存储(或者任何第三方的共享来存储)

        2.2用户登入成功之后,在后台生成一个UUID的唯一码,并把信息写入到redis(key为uuid,value为用户的信息,过期时间为12小时(可以根据业务需要改变)),同时在用户浏览器的cookie写入uuid

        2.3用户的每次浏览器点击(或者请求),浏览器都会自动把cookie加入请求的头部,后端代码这边读取request 的head,取出uuid,然后去redis上校验用户是否已经登入即可。

3、进一步的优化方案

          上述方案的弊端是每次用户的请求都会去请求redis,会导致redis压力较大。可以在用户登入成功之后,也设置session的值(request.getSession().setAttribute("XXX", XXXX))

,然后用户每次的请求都先读取session里面的值,session没有值才去读取redis上的内容(同时也设置一次session,防止下一次又去读取redis)。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值