调用链监控 - Tracing - APM

本文介绍了调用链监控在微服务领域的关键作用,详细阐述了调用链监控的原理和相关概念,如span、tid、sid等,并对比分析了CAT、Zipkin、Skywalking三款主流调用链监控产品的优缺点。强调了在选择调用链监控工具时,APM报表能力和定制开发能力的重要性。
摘要由CSDN通过智能技术生成

调用链监控原理和相关概念

微服务应用与单块应用完全不同,一个微服务系统少则有几十个微服务组成,多则可能有上百个服务。比如BAT级别的互联网公司,一般都超过上百个服务,服务之间的依赖关系错综复杂,如果没有有效的监控手段,那么出现问题很难快速排查,最终会导致业务损失。

在微服务监控领域,业界的实践证明,调用链监控 - tracing 是比较有效的手段,它不仅可以实时监控服务调用性能,也可以实时跟踪服务的依赖关系,出现问题的时候,通过调用链监控,可以帮助我们快速定位问题和排障,可以说微服务离不开调用链监控。

调用在分布式系统中的流程简述实例

在这里插入图片描述

调用链监控的核心原理并不复杂,下图简单描述的监控的原理和概念。

如图,假设有3个服务,service1, service2, service3. 他们之间是有调用关系的。

当外部请求进来的时候:

  1. 用户请求先到service1, service1调用redis缓存(红色小方块),redis返回service1数据。
  2. service1调用service2,service2调用mysql,mysql返回service2数据。
  3. service2调用service3, service3返回给service2
  4. service2返回给service1
  5. service1返回给用户<
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您正在使用 Spring Boot 3 和 micrometer-tracing-bridge-brave 进行 RabbitMQ 追踪,但无法获取到数据,可能是配置不正确或代码实现有误。 首先,您需要确保您的应用程序已正确配置 micrometer 和 rabbitmq。您可以在 `application.properties` 或 `application.yml` 配置文件中添加以下属性: ``` # micrometer management.metrics.export.tracing.enabled=true # rabbitmq spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest ``` 接下来,您需要在您的代码中添加以下依赖: ```xml <dependency> <groupId>io.micrometer</groupId> <artifactId>micrometer-core</artifactId> <version>${micrometer.version}</version> </dependency> <dependency> <groupId>io.micrometer</groupId> <artifactId>micrometer-registry-prometheus</artifactId> <version>${micrometer.version}</version> </dependency> <dependency> <groupId>io.micrometer</groupId> <artifactId>micrometer-registry-tracing</artifactId> <version>${micrometer.version}</version> </dependency> <dependency> <groupId>io.zipkin.brave</groupId> <artifactId>brave</artifactId> <version>${brave.version}</version> </dependency> <dependency> <groupId>io.zipkin.brave</groupId> <artifactId>brave-instrumentation-messaging-rabbitmq</artifactId> <version>${brave.version}</version> </dependency> ``` 其中 `${micrometer.version}` 和 `${brave.version}` 分别是 micrometer 和 brave 的版本号。 最后,您需要在您的代码中使用以下代码进行跟踪: ```java @Bean public Tracing tracing() { return Tracing.newBuilder() .localServiceName("your-service-name") .propagationFactory(Propagation.B3_FACTORY) .build(); } @Bean public Tracer tracer(Tracing tracing) { return tracing.tracer(); } @Bean public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory, Tracer tracer) { RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory); rabbitTemplate.setBeforePublishPostProcessors( TraceMessagePostProcessorBuilder .newInstance(tracer) .build() ); return rabbitTemplate; } ``` 这将创建一个跟踪实例,并在 RabbitMQ 消息发布之前添加跟踪信息。 希望这可以帮助您解决问题。如果有任何进一步的问题,请随时问我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值