微服务之间的信息传递---OpenFeign拦截器

上篇我们已经实现了从网关传递信息到微服务

新的问题是,微服务之间如何传递信息

前面我们在公共模块中定义拦截器并保存用户信息到了线程变量

但注意:

线程变量的作用域范围仅限于当前请求的线程。每个请求对应一个独立的线程变量,不同请求的数据是互不相干的,因此,不同的微服务实例间是无法共享ThreadLocal变量的。

如果一次请求经过了多个微服务,只有在单个微服务内才能访问到服务中的ThreadLocal的信息。

问题场景

如果用户信息经过验证后被保存在ThreadLocal中,并传递到订单服务,就可以根据这些信息创建用户订单。但是,当用户服务调用购物车服务以清空购物车时,ThreadLocal中的信息不会传递,因此无法获得用户信息,也就不清楚应该清空哪个用户的订单。

OpenFeign

HTTP请求客户端作为微服务间发送HTTP请求的工具,提供了一种解决方案,用以克服之前RestTemplate客户端在远程调用中遇到的服务治理问题。它通过注解来支持以接口方式发送RESTful请求,简化了开发者的工作,只需激活并调用接口方法,剩余的任务由Spring框架自动处理。

复制代码
开启:@EnableFeignClients(basePackages = "com.hmall.api.client"/

某个服务接口:

OpenFeign拦截器

由于调用购物车的服务是OpenFeign发起的,我们在OpenFeign发请求前携带请求头过去就可以了

每次发送请求前都会执行apply方法 进行拦截,然后对请求模板进行封装,以自定义请求信息。

(需在对应的微服务启动类上指定openfeign配置)

网关与微服务的通信https://mp.csdn.net/mp_blog/creation/editor/143430164

RestTemplate客户端https://mp.csdn.net/mp_blog/creation/editor/143351234

相关推荐
s1mple“”几秒前
互联网大厂Java面试实录:Spring Boot+微服务+AI技术栈深度问答
spring boot·微服务·java面试·ai技术·互联网大厂
啊西:1 分钟前
SuperMap iClient3D for WebGL与iObjects Java结合实现前端动态绘制面与体的布尔运算
java·3d·webgl
s1mple“”3 分钟前
基于电商场景的Java全栈面试实录:Spring Boot+微服务+AI技术深度解析
java·spring boot·微服务·高并发·分布式架构·电商系统·ai技术
Nakkhon6 分钟前
软件工程实践——个人技术博客
java·开发语言
好奇的菜鸟12 分钟前
Windows 环境下使用 Docker 部署 Java 开发中间件完全指南
java·windows·docker
代码or搬砖13 分钟前
== 和 equals() 的区别
java·开发语言·jvm
koping_wu17 分钟前
【leetcode】排序数组:快速排序、堆排序、归并排序
java·算法·leetcode
咘噜biu22 分钟前
Java SpringBoot后端Filter包装请求(新增/覆盖请求头)
java·spring boot·filter·requestwrapper
历程里程碑22 分钟前
LeetCode 283:原地移动零的优雅解法
java·c语言·开发语言·数据结构·c++·算法·leetcode
程序猿零零漆23 分钟前
Spring之旅 - 记录学习 Spring 框架的过程和经验(五)Spring的后处理器BeanFactoryPostProcessor
java·学习·spring