文档章节

log trace (2) - sleuth 支持dubbo

noob_fly
 noob_fly
发布于 2019/08/23 11:03
字数 286
阅读 112
收藏 0

3 月,跳不动了?>>>

spring-cloud-starter-sleuth 使用brave 的 Tracing 来实现日志trace输出

使用方法

maven:

	<dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-sleuth</artifactId>
		<version>2.1.1.RELEASE</version>
	</dependency>

	<dependency>
		<groupId>io.zipkin.brave</groupId>
		<artifactId>brave-instrumentation-dubbo-rpc</artifactId>
		<version>5.6.0</version>
	</dependency>

dubbo配置

dubbo.provider.filter: tracing
dubbo.consumer.filter: tracing

此处的tracing 对应的是 brave-instrumentation-dubbo-rpc 包内的 文件 com.alibaba.dubbo.rpc.Filter 配置的 brave.dubbo.rpc.TracingFilter 处理类。

核心类的执行流程

  1. org.springframework.cloud.sleuth.instrument.async.AsyncDefaultAutoConfiguration  
    1. TraceAsyncAspect 针对@Async注解,JoinPoint.proceed 执行前设置Span。
    2. ExecutorBeanPostProcessor.postProcessAfterInitialization  
      将定义的AsyncTaskExecutor封装wrapAsyncTaskExecutor:  createAsyncTaskExecutorProxy 构建LazyTraceAsyncTaskExecutor ,其核心是将runnable封装为TraceRunnable,在runnable.run 前开启新的Span.
  2. org.springframework.cloud.sleuth.annotation.SleuthAnnotationAutoConfiguration   
    1. SleuthAdvisorConfig -> 初始化SleuthInterceptor  来支持 @NewSpan 与 @ContinueSpan

      SleuthInterceptor.invoke ->NonReactorSleuthMethodInvocationProcessor.proceedUnderSynchronousSpan -> Trace.withSpanInScope

  3. org.springframework.cloud.sleuth.autoconfig.TraceAutoConfiguration  
    sleuthCurrentTraceContext方法:   
    给初始化 brave.propagation.ThreadLocalCurrentTraceContext(CurrentTraceContext的实现) 绑定 org.springframework.cloud.sleuth.log.SleuthLogAutoConfiguration  初始化的org.springframework.cloud.sleuth.log.Slf4jScopeDecorator (CurrentTraceContext内部接口ScopeDecorator的实现)

TracingFilter

在invoke时,通过com.alibaba.dubbo.rpc.RpcContext判定当前服务的角色:
consumer 从当前的Tracer中生成nextSpan,将span.context()扔入中com.alibaba.dubbo.rpc.RpcInvocation的attachments中,传递到provider去。
provider 从RpcInvocation中的Attachments获取传入的TraceContext,并joinSpan到当前trace。
(当然,如果为空,会生成新的TraceContext)

在真正的Invoker.invoke前
brave.Tracer.withSpanInScope -> brave.propagation.ThreadLocalCurrentTraceContext.newScope -> brave.propagation.CurrentTraceContext.decorateScope
-> org.springframework.cloud.sleuth.log.Slf4jScopeDecorator.decorateScope  设置MDC值

 

© 著作权归作者所有

noob_fly
粉丝 10
博文 139
码字总数 167640
作品 0
广州
程序员
私信 提问
加载中

评论(0)

Spring Cloud Sleuth 2.0.0 发布,支持 Dubbo

Spring Cloud Sleuth 2.0.0 已发布,更新内容包括: Rewritten using Brave #829, migration guide https://github.com/spring-cloud/spring-cloud-sleuth/wiki/Spring-Cloud-Sleuth-2.0-Mig......

淡漠悠然
2018/06/20
1.5K
2
基于docker部署的微服务架构(九): 分布式服务追踪 Spring Cloud Sleuth

前言 微服务架构中完成一项功能经常会在多个服务之间远程调用(RPC),形成调用链。每个服务节点可能在不同的机器上甚至是不同的集群上,需要能追踪整个调用链,以便在服务调用出错或延时较高时...

月冷X心寒
2016/11/28
2K
3
[Spring Cloud] 7 Spring Cloud Sleuth

Spring Cloud Sleuth 分布式链路跟踪 Spring Cloud Sleuth是Spring Cloud的分布式链路跟踪解决方案。 7.1 Terminology Spring Cloud Sleuth借鉴了Dapper的术语。 Span :最基本的工作单元。例...

秋雨霏霏
2017/02/08
2.7K
2
微服务SpringCloud之zipkin链路追踪

随着业务发展,系统拆分导致系统调用链路愈发复杂一个前端请求可能最终需要调用很多次后端服务才能完成,当整个请求变慢或不可用时,我们是无法得知该请求是由某个或某些后端服务引起的,这时...

社会主义接班人
2019/09/26
0
0
springcloud+springboot(十二):使用Spring Cloud Sleuth和Zipkin进行分布式链路跟踪

Spring Cloud Sleuth 一般的,一个分布式服务跟踪系统,主要有三部分:数据收集、数据存储和数据展示。根据系统大小不同,每一部分的结构又有一定变化。譬如,对于大规模分布式系统,数据存储...

itcloud
2018/12/03
1.2K
1

没有更多内容

加载失败,请刷新页面

加载更多

为什么只能在头文件中实现模板? - Why can templates only be implemented in the header file?

问题: Quote from The C++ standard library: a tutorial and handbook : 引用来自C ++标准库:教程和手册 : The only portable way of using templates at the moment is to implement t......

javail
今天
19
0
Gradle 6 针对已有的构建如何创建一个构建扫描

有关构建扫描的定义为: 构建扫描(build scan)是一个中心化并且可以共享的构建记录。这个构建记录通常能够告诉在构建中发生了什么并且为什么会发生。 通过应用构建扫描插件到你的项目中,你...

honeymoose
今天
17
0
C语言动态内存分配:(一)malloc/free的实现及malloc实际分配/释放的内存

一、malloc/free概述 malloc是在C语言中用于在程序运行时在堆中进行动态内存分配的库函数。free是进行内存释放的库函数。 1、函数原型 #include <stdlib.h> void *malloc( size_t size ); v...

shzwork
今天
17
0
什么是JavaBean? - What is a JavaBean exactly?

问题: I understood, I think, that a "Bean" is a Java class with properties and getters/setters. 我认为,“ Bean”是具有属性和getter / setter的Java类。 As much as I understand,......

技术盛宴
今天
27
0
深圳援鄂最后一批工作人员归来,88万元关爱金发放至85人

中国公益在线3月31日深圳讯 深圳援鄂最后一批工作人员归来......深圳市民政局、深圳市卫健委和深圳市慈善会发起了“深爱战疫天使基金”项目,联合龙华区慈善会和 永贤慈善基金会,进行第二次...

传承天下融媒体中心
今天
15
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部