美文网首页
Redis 分布式会话入门

Redis 分布式会话入门

作者: 小P聊技术 | 来源:发表于2021-02-24 08:30 被阅读0次

    1 会话

    会话Session代表的是客户端与服务器的一次交互过程,这个过程可以是连续也可以是时断时续的。曾经的Servlet时代(jsp),一旦用户与服务端交互,服务器用户创建一个session,同时前端会有一个jsessionid,每次交互都会携带。如此一来,服务器只要在接到用户请求时候,就可以拿到jsessionid,并根据这个ID在内存中找到对应的会话session,当拿到session会话后,那么我们就可以操作会话了。

    会话存活期间,我们就能认为用户一直处于正在使用着网站的状态,一旦session超期过时,就可以认为用户已经离开网站,停止交互了。用户的身份信息,我们也是通过session来判断的,在session中可以保存不同用户的信息。
    session的使用之前在单体部分演示过,代码如下:

        @GetMapping("/setSession")
        public Object setSession(HttpServletRequest request) {
            HttpSession session = request.getSession();
            session.setAttribute("userInfo","new User");
            session.setMaxInactiveInterval(3600);
            session.getAttribute("userInfo");
    //        session.removeAttribute("userInfo");
            return "ok";
        }
    

    2 无状态会话

    HTTP请求是无状态的,用户向服务端发起多个请求,服务端并不会知道这多次请求都是来自同一用户,这个就是无状态的 。cookie的出现就是为了有状态的记录用户。

    常见的前后端分离交互,小程序与服务端交互,安卓与服务端交互,他们都是通过http请求来调用接口,每次交互服务端都不会拿到客户端的状态,我们一般会在每次请求的时候都携带userId或者token,这样后台就可以根据用户ID或者token来获取响应的请求,这样每个用户的下一次请求都能被服务端识别来自同一个用户。

    3 有状态会话

    Tomcat中的会话,就是有状态的,一旦用户和服务端交互,就有会话,会话保存了用户的信息,这样用户就“有状态”了,服务端会和每个客户端都保持着这样的一层关系,这个由容器来管理(也就是tomcat),这个session会话是保存到内存空间里的,如此一来,当不同的用户访问服务端,通过会话就可以找到对应的访问者信息。

    tomcat会话的出现也是为了让http请求变的有状态。如果用户不再和服务端交互,那么会话超时则消失,结束了他的生命周期。如此一来,每个用户其实都会有一个会话被维护,这就是有状态会话。
    场景:在传统项目或者jsp项目中是使用的最多的session都是有状态的,session的存在就是为了弥补http的无状态。

    • tomcat会话可以通过手段实现多系统之间的状态同步,但是会损耗一定的时间,一旦发生同步那么用户请求就会等待,不建议使用这种方式。

    4 单Tomcat会话

    先来看一下单个tomcat会话,这个就是有状态的,用户首次访问服务端,这个时候会话产生,并且会设置jsessionid放入cookie中,后续每次请求都会携带jsessionid以保持用户状态 。

    单Tomcat会话.png

    5 动静分离会话

    用户请求服务端,由于动静分离,前端发起http请求,不会携带任何状态,当用户第一次请求之后,我们手动设置一个token,作为用户会话,放入redis中,如此作为redis-session,并且这个token设置后放入前端cookie中(app或者小程序可以放到本地缓存),如此后续交互过程中,前端只需要传递token给后端,后端统一解析就可以知道具体的某个用户请求。

    在这里插入图片描述

    6 集群分布式会话

    集群或者分布式系统本质都是多个系统,假设有两个服务器节点,分别是AB系统,他们可以是集群,也可以是分布式系统,一开始用户和A系统进行交互,那么这个时候的用户状态,我们可以保存在redis中,作为A系统的会话信息。随后用户的请求进入到B系统,那么B系统中的会话也同样与redis关联,如此AB系统的session就统一了。当然cookie是会随用户的访问携带过来的,那么这个其实就是分布式会话,通过redis来保存用户信息。

    在这里插入图片描述

    7 类似关系:局部变量与全局变量

    Tomcat会话相当于一个类中的某个方法的局部变量,只能在当前方法中使用。

    分布式会话,相当于一个类中的公用全局变量,可以被类中的诸多方式使用。

    如下代码:

    public class DistributedClusterTest {
      
      public String distributedSession = "global-1001";
      
      public void ASystem() {
        String aSession = "a-2001";
        System.out.println(distributedSession);
        System.out.printlnaSession();
      }
     
       public void BSystem() {
        String bSession = "a-3001";
        System.out.println(distributedSession);
        System.out.printlnaSession();
      }
     
    }
    

    distributedSession是这个类的全局变量,可以在其他方法中被使用到,而 aSessionbSession实在方法中的局部变量,局部变量只能在本方法中使用,全局变量在其他方法里面都可以使用。分布式会话和单个tomcat会话也是这个道理。

    8 相关信息

    • 博文不易,辛苦各位猿友点个关注和赞,感谢

    相关文章

      网友评论

          本文标题:Redis 分布式会话入门

          本文链接:https://www.haomeiwen.com/subject/fmalfltx.html