在分布式系统中,session是需要共享的
整合SpringSession解决服务session共享问题
1,引入依赖spring-session
2,session的保存地方使用redis(配置文件指定spring.session.store=redis)
3,在把session放到客户端时
问题:其他服务与该session不能共享,且存入的数据在redis时java默认的序列化
所以必须自定义SpringSession
1,编写Configuration,把cookieSerializer放入容器
2,cookieSerializer中设置作用域(domainName)
3,另外可以设置cookie中其他参数
redis存储json数据
需要把redisSerializer放入容器中
@Bean
public RedisSerializer redisSerializer() {
return new FastJsonRedisSerializer();//也可以用GenericJackson2JsonRedisSerializer()
}
Springboot拦截器
1,编写拦截器实现handlerInterceptor接口
2,把拦截器放入spring拦截器链中:创建类实现WebMvcConfigure,实现addInterceptors,把1步骤中的拦截器加入该拦截器链
Feign远程调用丢失请求头问题
feign在每个远程调用前都会调用RequestInterceptor的apply方法
编写feign的Configuration,返回RequestInterceptor配置类放入容器,
重写apply方法,把RequestContextHolder中获取的cookie放入RequestTemplate头
如果方法中开异步线程执行,需要在开启异步线程前先获取主线程
RequestAttributes attr = RequestContextHolder.getRequestAttributes();
再把主线程获取到的attr放入新开的线程里RequestContextHolder.setRequestAttributes(attr);
分布式事务seata:
详见官方文档http://seata.io/zh-cn/docs/user/quickstart.html
也可以使用MQ做分布式事务
sentinel(流量控制)
官方文档:https://sentinelguard.io/zh-cn/docs/dashboard.html
sleuth+zipkin (链路追踪)