第9章 分布式会话
由于HTTP是无状态协议,每次发起请求时服务端并不知道各个请求之间的关系,为解决这个问题,引入了Session与Cookie配合记录客户端(浏览器)所发起的请求。
当打开浏览器发起HTTP请求时,服务端的Session生成一个全局统一标识(session_id
),并将这个标识发送给客户端存储于Cookie中。基于该统一标识便可管理当前浏览器所发起的请求之间的关系。Spring Boot中的基于内嵌的Tomcat容器将Session存储于内存中,在分布式环境中由于各微服务应用运行于不同的环境,所以各Session之间无法互通。
Spring Session 通过标准的Servlet Filter(过滤器)拦截所有的Web请求,并且重写了HttpServlet Request
的getSession()
方法,将Session交由Redis存储,多个微服务应用使用同一Redis管理的Session,从而最终实现统一的分布式会话管理。
由于Dubbo的各微服务模块并非在Web容器中运行,所以分布式Session会话在Spring Cloud中使用,不过在设计架构时尽量还是使用无状态的服务接口。
① 在pom.xml
中引入依赖。
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
</dependency>
<dependency>
<