在集群系统中,微服务间通常需要将session共享,否则用户明明在服务A登录过了,在服务B又要重新登录,会带来很差的用户体验
什么是session
session是服务器端的一个 key-value 的数据结构,经常和 Cookie 配合,保持用户的登陆会话。客户端在第一次访问服务端的时候,服务端会响应一个 SessionId 并且将它存入到本地 Cookie 中,在之后的访问中浏览器会将 Cookie 中的 sessionId 放入到请求头中去访问服务器,如果通过这个 SessionId 没有找到对应的数据,那么服务器会创建一个新的SessionId并且响应给客户端
分布式session的解决方案
- 利用三方件来存取session(数据库、redis等,因为吞吐量和性能问题,通常选redis)
- 使用Token代替session(也是比较推荐的方案,但不是本文的重点)
源码解读
首先通过spring-boot-autoconfigure中org.springframework.boot.autoconfigure.data.redis.RedisAutoConfiguration自动装配
@Configuration(proxyBeanMethods = false)
@ConditionalOnClass(RedisOperations.class)
@EnableConfigurationProperties(RedisProperties.class)
@Import({ LettuceConnectionConfiguration.class, JedisConnectionConfiguration.class })
public class RedisAutoConfiguration {
@Bean
@ConditionalOnMissingBean(name = "redisTemplate")
@ConditionalOnSingleCandidate(RedisConnectionFactory.class)
public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate<Object, Object> template = new RedisTemplate<>();
template.setConnectionFactory(redisConnectionFactory);
return template;
}
@Bean
@ConditionalOnMissingBean
@ConditionalOnSingleCandidate(RedisConnectionFactory.class)
public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) {
return new StringRedisTemplate(redisConnectionFactory);
}
}