Spring Cloud中Hystrix 线程隔离导致ThreadLocal数据丢失问题分析
2024-09-01 10:47:20
最近spring boot项目中由于使用了spring cloud 的hystrix 导致了threadLocal中数据丢失,其实具体也没有使用hystrix,但是显示的把他打开了,导致了此问题。
导致此问题的代码逻辑如下:服务之间的调用采用的feignclient,采用feignclient拦截器获取上游设置到threadlocal中的数据。
@Slf4j
public class TenantSupportInterceptor implements RequestInterceptor { public void apply(RequestTemplate template) {
String tenantNo = Optional.ofNullable(LocalHolder.getTenantNo());
template.header(CommonConstants.TENANT_NO, tenantNo);
} }
public final class LocalHolder { private LocalHolder() {
} private static final InheritableThreadLocal<String> TENANT_NO_THREADLOCAL = new InheritableThreadLocal<>(); public static void setTenantNo(String tenantNo) {
TENANT_NO_THREADLOCAL.set(tenantNo);
} public static String getTenantNo() {
return TENANT_NO_THREADLOCAL.get();
} public static void removeTenantNo() {
TENANT_NO_THREADLOCAL.remove();
}
}
具体为什么采用InheritableThreadLocal下文有说明。
但是有时候就拿不到。经过排查,这两边的线程发生了变化,导致取不到值。导致线程发生变化的原因是显示的声明了hystrix为true。
只需要把这个设置成false就好。
但是如果项目中真真的是用了hystrix呢?
引用一下文档进行说明:
和
https://cloud.tencent.com/developer/article/1082737
最新文章
- [转]nginx+fastcgi+c/c++搭建高性能Web框架
- Hadoop2.2 federnation联盟的搭建
- Java基础知识强化之集合框架笔记41:Set集合之HashSet存储自定义对象并遍历练习
- 管理工具 Kafka Manager
- Linux之例行(任务调度)
- An Introduction to Stock Market Data Analysis with R (Part 1)
- 查找命令which、whereis、locate
- HTML5_canvas_图片加载_双缓冲_跳帧闪烁问题
- 002_关于six版本过低报cannot import name urllib_parse的问题
- mongodb系列~mongodb定时删除数据
- java并发编程艺术
- 23个Python爬虫开源项目代码
- Python itsdangerous 生成token和验证token
- JS高程研读记录一【事件流】
- shell教程-002:常见的Shell种类
- Spark分析之启动流程
- asp.net如何隐藏表格(table)的一行
- android 时间控件概述
- html5的常用函数
- BZOJ4415:[SHOI2013]发牌(线段树)