微服务之间的信息传递---OpenFeign拦截器
https://i-blog.csdnimg.cn/direct/e7ba3bd6259b42a390252b405c5ea3bf.png上篇我们已经实现了从网关传递信息到微服务。
新的问题是,微服务之间怎样传递信息。
前面我们在公共模块中定义拦截器并生存用户信息到了线程变量。
但注意:
线程变量的作用域范围仅限于当前请求的线程。每个请求对应一个独立的线程变量,不同请求的数据是互不干系的,因此,不同的微服务实例间是无法共享ThreadLocal变量的。
如果一次请求经过了多个微服务,只有在单个微服务内才华访问到服务中的ThreadLocal的信息。
问题场景
如果用户信息经过验证后被生存在ThreadLocal中,并传递到订单服务,就可以根据这些信息创建用户订单。但是,当用户服务调用购物车服务以清空购物车时,ThreadLocal中的信息不会传递,因此无法获得用户信息,也就不清楚应该清空哪个用户的订单。
OpenFeign
HTTP请求客户端作为微服务间发送HTTP请求的工具,提供了一种办理方案,用以降服之前RestTemplate客户端在远程调用中碰到的服务治理问题。它通过注解来支持以接口方式发送RESTful请求,简化了开发者的工作,只需激活并调用接口方法,剩余的使命由Spring框架主动处置处罚。
开启:@EnableFeignClients(basePackages = "com.hmall.api.client"/ 某个服务接口:
https://i-blog.csdnimg.cn/direct/19bddf63e83e48adb9004a57478932b8.png
OpenFeign拦截器
由于调用购物车的服务是OpenFeign发起的,我们在OpenFeign发请求前携带请求头过去就可以了
每次发送请求前都会实验apply方法进行拦截,然后对请求模板进行封装,以自定义请求信息。
https://i-blog.csdnimg.cn/direct/139cff93f88743fba48219d1b7482f71.png
(需在对应的微服务启动类上指定openfeign设置)
网关与微服务的通信https://csdnimg.cn/release/blog_editor_html/release2.3.7/ckeditor/plugins/CsdnLink/icons/icon-default.png?t=O83Ahttps://mp.csdn.net/mp_blog/creation/editor/143430164
RestTemplate客户端https://csdnimg.cn/release/blog_editor_html/release2.3.7/ckeditor/plugins/CsdnLink/icons/icon-default.png?t=O83Ahttps://mp.csdn.net/mp_blog/creation/editor/143351234
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]