当前位置: 首页 > article >正文

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

                           

             

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

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

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

但注意:

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

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

问题场景

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

OpenFeign

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

开启:@EnableFeignClients(basePackages = "com.hmall.api.client"/

某个服务接口: 

OpenFeign拦截器

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

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

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

网关与微服务的通信icon-default.png?t=O83Ahttps://mp.csdn.net/mp_blog/creation/editor/143430164

RestTemplate客户端icon-default.png?t=O83Ahttps://mp.csdn.net/mp_blog/creation/editor/143351234 


http://www.kler.cn/a/382780.html

相关文章:

  • C语言例题练手(1)
  • 一文搞懂Linux kernel编译步骤
  • 进程与线程+多线程优势
  • linux node vue3 部署手册
  • MySQL45讲 第十讲 MySQL为什么有时候会选错索引?
  • Qt中的Model与View 4:QStandardItemModel与QTableView
  • [OS] Prerequisite Knowledge about xv6
  • 【LeetCode】【算法】155. 最小栈
  • 常用查找算法count_if
  • 基于JavaWeb的宿舍管理系统的设计与实现
  • 【游戏引擎之路】登神长阶(十二)——DirectX11教程:If you‘re going through hell, keep going!
  • 英伟达的cuda和人工智能快车
  • ubuntu 22.04 server 安装 anaconda3
  • 【Zynq FPGA】基于 Zynq FPGA 的雷龙 SD NAND 测试
  • Java 8 Lambda 表达式和函数式接口的底层实现机制详解
  • 【Linux】【守护进程】总结整理
  • 【AI开源项目】FastGPT - 快速部署FastGPT以及使用知识库的两种方式!
  • hive表内外表之间切换
  • Docker 镜像拉不动?自建 Docker Hub 加速站 解决镜像拉取失败
  • 非凸科技助力第49届ICPC亚洲区域赛(成都)成功举办
  • ELK-ELK基本概念_ElasticSearch的配置
  • 立冬:冬日序曲的温柔启幕
  • Renesas R7FA8D1BH (Cortex®-M85) 存储空间介绍
  • 无人机之飞行管控平台篇
  • Linux查看端口占用及Windows查看端口占用
  • 电话语音机器人,是由哪些功能构成?