Closed xucw closed 6 months ago
@xucw 你提到的「从网关传递的上下文是否支持全链路传递」是 分布式追踪方案/领域所关注与解决的问题,很重要。 👍 ♥️
分布式追踪,业界已经有很多很好的实现。下文有些介绍:
分布式追踪关注的内容 比TTL
复杂得多大得多;实现上可以用到TTL
。
对于TTL
的使用场景,分布式追踪(包含涉及的各个设施/中间件集成)相比其它场景,大家讨论得比较多。下面的内容有些说明与讨论:
其它的TTL
使用场景(如DB
的事务管理,看起来场景和分布式追踪相去很远),下面的issue中有一些说明:
TTL在类似这种场景下,从网关传递的上下文是否支持全链路传递?
@xucw 回到你提的问题上:
TTL
的功能/职责/定位 只是个 简单的ThreadLocal
库,不会扩展到(成熟繁荣的)「分布式追踪」上。
a missing Java std lib(simple & 0-dependency) for framework/middleware, provide an enhanced InheritableThreadLocal that transmits values between threads even using thread pooling components.
关于TTL
的功能/职责,在下面这个Issue中,也有一些讨论与说明:
在微服务架构中,假如有这的链路:网关->A->B->C->D->E。其中,网关到A服务是http调用,A服务到B服务是通过RocketMQ协议,即A是生产者,B是消费者。B服务到C服务是http调用,C服务到D服务也是通过RocketMQ协议,即C是生产者,D是消费者。D服务到E服务是http调用。 TTL在类似这种场景下,从网关传递的上下文是否支持全链路传递?