Redis 分布式会话入门

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以保持用户状态 。

在这里插入图片描述

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 相关信息

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

猜你喜欢

转载自blog.csdn.net/qq_15769939/article/details/113969476