Tip: 此篇已加入.NET Core微服务基础系列文章索引

=>  Steeltoe目录快速导航

1. 基于Steeltoe使用Spring Cloud Eureka

2. 基于Steeltoe使用Spring Cloud Zuul

3. 基于Steeltoe使用Spring Cloud Hystrix

4. 基于Steeltoe使用Spring Cloud Config

5. 基于Steeltoe使用Zipkin

一、关于Spring Cloud Sleuth与Zipkin

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

  

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

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

二、快速构建Zipkin Server

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

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

    <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- 热启动,热部署依赖包,为了调试方便,加入此包 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><optional>true</optional></dependency><!-- zipkin --><dependency><groupId>io.zipkin.java</groupId><artifactId>zipkin-autoconfigure-ui</artifactId></dependency><dependency><groupId>io.zipkin.java</groupId><artifactId>zipkin-server</artifactId></dependency></dependencies><!-- spring cloud dependencies --><dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Edgware.SR3</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement>

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

@SpringBootApplication
@EnableZipkinServer
public class ZipkinServiceApplication {public static void main(String[] args) {SpringApplication.run(ZipkinServiceApplication.class, args);}
}

  (3)配置文件

server:port: 9411spring:application:name: zipkin-service

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

三、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之后的服务列表:

  

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 class Program{......public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>WebHost.CreateDefaultBuilder(args).UseUrls("http://*:8030").UseStartup<Startup>().ConfigureLogging((builderContext, loggingBuilder) =>{loggingBuilder.AddConfiguration(builderContext.Configuration.GetSection("Logging"));// Add Steeltoe Dynamic Logging Provider
                    loggingBuilder.AddDynamicConsole();});}

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

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

    public class Startup{......public void ConfigureServices(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 void Configure(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 

  

  (3)通过Zipkin UI查看Trace

  

  点击具体的Trace查看Details

  

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

  

五、小结

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

示例代码

  GitHub => https://github.com/EdisonChou/Microservice.PoC.Steeltoe/tree/master/src/Chapter4-ServiceTracing

参考资料

Steeltoe官方文档:《Steeltoe Doc》

Steeltoe官方示例:https://github.com/SteeltoeOSS/Samples

周立,《Spring Cloud与Docker 微服务架构实战》

小不点啊,《SpringCloud系列十二:SpringCloudSleuth(SpringCloudSleuth 简介、SpringCloudSleuth 基本配置、数据采集)》

Ken.W,《Steeltoe之Distributed Tracing篇》

作者:周旭龙

出处:http://edisonchou.cnblogs.com

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

转载于:https://www.cnblogs.com/edisonchou/p/dotnet_core_microservice_integrate_with_zipkin.html

.NET Core微服务之基于Steeltoe使用Zipkin实现分布式追踪相关推荐

  1. .NET Core微服务之基于Ocelot实现API网关服务(续)

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.负载均衡与请求缓存 1.1 负载均衡 为了验证负载均衡,这里我们配置了两个Consul Client节点,其中ClientServic ...

  2. .NET Core微服务之基于IdentityServer建立授权与验证服务(续)

    上一篇<.NET Core微服务之基于IdentityServer建立授权与验证服务>我们基于IdentityServer4建立了一个AuthorizationServer,并且继承了Qu ...

  3. .NET Core微服务之基于Ocelot实现API网关服务

    一.啥是API网关? API 网关一般放到微服务的最前端,并且要让API 网关变成由应用所发起的每个请求的入口.这样就可以明显的简化客户端实现和微服务应用程序之间的沟通方式.以前的话,客户端不得不去请 ...

  4. .NET Core微服务之基于Consul实现服务治理

    一.Consul基础介绍 Consul是HashiCorp公司推出的开源工具,用于实现分布式系统的服务发现与配置.与其他分布式服务注册与发现的方案,比如 Airbnb的SmartStack等相比,Co ...

  5. .NET Core微服务之基于MassTransit实现数据最终一致性(Part 1)

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.预备知识:数据一致性 关于数据一致性的文章,园子里已经有很多了,如果你还不了解,那么可以通过以下的几篇文章去快速地了解了解,有个感性认 ...

  6. .NET Core微服务之基于Ocelot+IdentityServer实现统一验证与授权

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.案例结构总览 这里,假设我们有两个客户端(一个Web网站,一个移动App),他们要使用系统,需要通过API网关(这里API网关始终作为 ...

  7. .NET Core微服务之基于Consul实现服务治理(续)

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 上一篇发布之后,很多人点赞和评论,不胜惶恐,这一篇把上一篇没有弄到的东西补一下,也算是给各位前来询问的朋友的一些回复吧. 一.Consul ...

  8. .NET Core微服务之基于EasyNetQ使用RabbitMQ消息队列

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.消息队列与RabbitMQ 1.1 消息队列 "消息"是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含 ...

  9. .NET Core微服务之基于Exceptionless实现分布式日志记录

    一.Exceptionless极简介绍 Exceptionless 是一个开源的实时的日志收集框架,它可以应用在基于 ASP.NET,ASP.NET Core,Web API,Web Forms,WP ...

  10. .NET Core微服务之基于IdentityServer建立授权与验证服务

    一.IdentityServer的预备知识 要学习IdentityServer,事先得了解一下基于Token的验证体系,这是一个庞大的主题,涉及到Token,OAuth&OpenID,JWT, ...

最新文章

  1. 一文介绍机器学习中的三种特征选择方法
  2. PHP7 RC7 Release对比PHP5.6快速排序20000数据性能体验以及新语法尝鲜
  3. 100多个Android Demo的整合
  4. Python 缩进问题-inconsistent use of tabs and spaces in indentation.原因及解决方法
  5. 2021-04-29 Python绘制柱状图之可视化神器Pyecharts
  6. ABP VNext实践之搭建可用于生产的IdentityServer4
  7. Spring Boot中登录错误消息的显示
  8. 直播App测试重点问题 - 服务器压力
  9. 为什么说要注销 QQ 的,都是君子呢?
  10. 人工智能与机器学习大牛们的blog
  11. 电商系统设计之商品 (上)
  12. 【微服务直播】60分钟掌握微服务治理之道
  13. shell 的AWK
  14. 十大经典算法图解(详细版)
  15. 重大噩耗:苹果账号无法付款!(11-20更新:账单地址和卡地址一样,信用卡名字和开发者名字一致,都无法付款)
  16. 6岁女孩出口之乎者也 用《论语》典故批评妈妈
  17. 基于51单片机万年历
  18. 笔记本电脑桌面上计算机打不开怎么办,笔记本电脑开了机一直进不去桌面怎么办...
  19. 多元线性回归及案例(Python)
  20. C++PrimerPlus 学习笔记 | 第八章 函数探幽 | 2.引用参数

热门文章

  1. matlab实现m-k突变的,用matlab进行mk趋势分析与突变检验.pdf
  2. pandas输出到excel_精通Pandas,从零基础到中级运用,看这一篇就够了
  3. iphone分屏功能怎么用_除iOS12.4苹果还为旧款设备推送了更新 来看iPhone迁移怎么用...
  4. 【牛客网小白月赛12】华华听月月唱歌(贪心+区间覆盖问题)
  5. STM32——库函数流水灯程序
  6. 守望先锋 获取cdn配置_英特尔酷睿i5 9400F万金油配置推荐 适合吃鸡 守望先锋
  7. MCS:连续随机变量——Beta分布
  8. Meta-Programming in Python
  9. DL-C1-week3-1(build a neural network with one hidden layer)多层感知机的简单实现
  10. 容器技术Docker K8s 53 边缘容器服务(ACK@Edge)-阿里云边缘容器服务