zipkin mysql edgware_.NET Core微服务之基于Steeltoe使用Zipkin实现分布式追踪

一、关于Spring Cloud Sleuth与Zipkin

在 SpringCloud 之中提供的 Sleuth 技术可以实现微服务的调用跟踪,也就是说它可以自动的形成一个调用连接线,通过这个连接线使得开发者可以轻松的找到所有微服务间关系,同时也可以获取微服务所耗费的时间, 这样就可以进行微服务调用状态的监控以及相应的数据分析。

1b0b4076f1181ad09bde5acb7724aba7.png

Zipkin是一个分布式追踪系统,它有助于收集解决微服务架构中延迟问题所需的时序数据。它管理这些数据的收集和查找。

应用程序用于向Zipkin报告时间数据。Zipkin UI还提供了一个依赖关系图,显示每个应用程序有多少跟踪请求。如果你正在解决延迟问题或错误问题,则可以根据应用程序,跟踪长度,注释或时间戳过滤或排序所有跟踪。一旦选择了一个跟踪,你可以看到每个跨度所花费的总跟踪时间的百分比,从而可以确定问题应用程序。

二、快速构建Zipkin Server

示例版本:Spring Boot 1.5.15.RELEASE,Spring Cloud Edgware.SR3

(1)pom.xml 添加相关依赖包

org.springframework.boot

spring-boot-starter-web

org.springframework.boot

spring-boot-devtools

true

io.zipkin.java

zipkin-autoconfigure-ui

io.zipkin.java

zipkin-server

org.springframework.cloud

spring-cloud-dependencies

Edgware.SR3

pom

import

(2)启动类添加相关注解

@SpringBootApplication

@EnableZipkinServerpublic classZipkinServiceApplication {public static voidmain(String[] args) {

SpringApplication.run(ZipkinServiceApplication.class, args);

}

}

(3)配置文件

server:

port:9411spring:

application:

name: zipkin-service

最终启动后,访问zipkin主界面:

4e531278185b4ffe3670867fd269c87e.png

三、ASP.NET Core集成Zipkin

3.1 示例环境准备

这里仍然基于第一篇的示例进行修改,各个项目的角色如下表所示:

微服务项目名称

项目微服务中的角色

eureka-service

服务发现&注册(Spring Boot)

zuul-service

API网关 (Spring Boot)

zipkin-service

分布式追踪服务 (Spring Boot)

agent-service

服务提供者 (ASP.NET Core)

client-service

服务提供者 (ASP.NET Core)

premium-service

服务提供者&服务消费者(ASP.NET Core)

所有相关服务(除zipkin-service外)注册到Eureka之后的服务列表:

16278c8d86944f8abb29c120bc6f3296.png

3.2 想要测试的服务调用链路

浏览器通过API网关(Zuul)调用Premium-Service的API,在这个API中会调用Client-Service的API,当然,会通过服务发现(Eureka)来获取Client-Service的URL。

3.3 以PremiumService为例添加相关配置

这里以PremiumService为例,其他几个Service参照下面的步骤依次添加配置即可。

(1)添加相关NuGet包

PM> Install-Package Steeltoe.Extensions.Logging.DynamicLogger

PM> Install-Package Steeltoe.Management.ExporterCore

PM> Install-Package Steeltoe.Management.TracingCore

(2)Program类添加动态日志Provider

public classProgram

{

......public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>WebHost.CreateDefaultBuilder(args)

.UseUrls("http://*:8030")

.UseStartup()

.ConfigureLogging((builderContext, loggingBuilder)=>

{

loggingBuilder.AddConfiguration(builderContext.Configuration.GetSection("Logging"));

// Add Steeltoe Dynamic Logging ProviderloggingBuilder.AddDynamicConsole();

});

}

Steeltoe的日志提供器是对ASP.NET Core自身日志器的进一步封装,其在原始数据基础上增加了如Spring Cloud Sleuth中一样的额外信息。

(3)Starup启动类中添加相关配置

public classStartup

{

......public voidConfigureServices(IServiceCollection services)

{

......//Add Steeltoe Distributed Tracing

services.AddDistributedTracing(Configuration);//Export traces to Zipkin

services.AddZipkinExporter(Configuration);

services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);//Add Hystrix Metrics to container

services.AddHystrixMetricsStream(Configuration);

}public voidConfigure(IApplicationBuilder app, IHostingEnvironment env)

{

......

app.UseMvc();//Start Hystrix metrics stream service

app.UseHystrixMetricsStream();//Start up trace exporter

app.UseTracingExporter();

}

}

(4)appSettings添加相关配置 => 主要是zipkin server的相关信息

"management": {"tracing": {"alwaysSample": true,"egressIgnorePattern": "/api/v2/spans|/v2/apps/.*/permissions|/eureka/.*|/oauth/.*","exporter": {"zipkin": {"endpoint": "http://localhost:9411/api/v2/spans","validateCertificates": false}

}

}

}

四、快速验证测试

(1)启动Eureka, Zuul, Zipkin以及Premium-Service和Client-Service

(2)通过Zuul调用API

e39efcb6a1bc5f91ad84752fb2cc7578.png

(3)通过Zipkin UI查看Trace

f2c5fd30d6ad6e71297fb24a3596a646.png

点击具体的Trace查看Details

4604945baa9c9bee2f9a4f4bea0f0899.png

(4)点击“依赖分析”按钮查看依赖图

71eb6b6c6694a68adc9b19ae11331dd3.png

五、小结

本文简单地介绍了一下Spring Cloud Seluth与Zipkin,然后通过Java快速地构建了一个Zipkin Server,通过在ASP.NET Core中集成Zipkin并做了一个基本的微服务调用追踪Demo。本示例的Zipkin Server的追踪数据是基于内存,实际中应该集成ELK进行持久化。当然,我们也可以直接通过Zipkin的.NET客户端来做。

示例代码

参考资料

Steeltoe官方文档:《Steeltoe Doc》

作者:周旭龙

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值