博客
关于我
原来10张图就可以搞懂分布式链路追踪系统原理
阅读量:362 次
发布时间:2019-03-04

本文共 1324 字,大约阅读时间需要 4 分钟。

分布式系统中的链路追踪技术

随着互联网业务的快速扩展,软件架构日益复杂,分布式系统逐渐成为主流。微服务化、分布式缓存、分布式消息等技术的应用,使得系统组件变得更加复杂。在实际运行中,面对系统错误时,如何快速定位问题成为开发人员和运维人员的重要课题。

链路追踪的必要性

在分布式系统中,一个单独的请求可能经过成千上万个服务节点完成。例如,用户在浏览器上下单,一箱茅台酒,系统提示“系统内部错误”。运维人员需要定位问题,但仅凭异常信息,开发人员无法知道具体是哪个微服务导致问题。这时候,逐个排查每个服务的效率非常低下。

为了提高排查效率,引入链路追踪系统成为一种有效的解决方案。通过链路追踪,可以将一次分布式请求还原成完整的调用链路,展示各个服务节点的耗时、请求路径等信息,从而快速定位问题所在。

链路追踪的核心概念

  • Trace(链路)

    Trace是请求在各个服务节点间传播的唯一标识符,串联起整个请求的调用链路。

  • Span(跨度)

    Span用于表达请求在各个服务节点间的父子关系。同一层级的Span具有相同的父ID,Span ID则表示请求的顺序。

  • Annotation(注解)

    用于标记请求的各个阶段,如客户端开始请求(cs)、服务端接收请求(sr)、服务端处理完成并发送响应(ss)、客户端接收响应(cr)。这些注解信息有助于分析请求的全生命周期。

  • 带内数据与带外数据

    • 带外数据:由各个节点独立生成,用于存储链路的详细信息,如Annotation事件。
    • 带内数据:包括Trace ID、Span ID、Parent ID等,用于串联链路的各个部分。
  • 采样机制

    为了减少存储和带宽的消耗,链路追踪系统采用采样机制。例如,设置采样率为1/1000,只有1%的请求数据被上报。

  • 存储机制

    链路数据的存储需要考虑高效性和可扩展性。Zipkin等工具通常使用BigTable、ElasticSearch、HBase等存储解决方案。

  • 业界领先的开源组件

    基于Google的Dapper论文,Twitter开发的Zipkin、Uber的Jaeger、Apache的SkyWalking等工具成为行业内领先的链路追踪解决方案。这些工具提供了标准化接口,确保不同系统间的兼容性。

    Zipkin的实现架构

    Zipkin由四大核心组件构成:

  • Collector(采集器)

    收集链路追踪数据,进行验证和存储。

  • Storage(存储器)

    最初基于Cassandra,后续支持ElasticSearch和MySQL等存储解决方案。

  • Query Service(查询服务)

    提供API接口,帮助运维人员快速检索链路数据。

  • Web UI(网页用户界面)

    提供直观的查询界面,便于运维人员分析链路数据。

  • 通过这些组件的协作,Zipkin能够高效地收集、存储和查询链路数据,为系统问题定位提供有力支持。

    总结

    分布式链路追踪技术通过还原分布式请求的调用链路,显著提升了问题定位的效率。核心概念包括Trace、Span、Annotation、带内和带外数据、采样机制和存储解决方案。Zipkin等开源工具为行业提供了成熟的解决方案,帮助开发人员和运维人员更高效地管理和优化分布式系统。

    转载地址:http://blbr.baihongyu.com/

    你可能感兴趣的文章
    No compiler is provided in this environment. Perhaps you are running on a JRE rather than a JDK?
    查看>>
    no connection could be made because the target machine actively refused it.问题解决
    查看>>
    No Datastore Session bound to thread, and configuration does not allow creation of non-transactional
    查看>>
    No fallbackFactory instance of type class com.ruoyi---SpringCloud Alibaba_若依微服务框架改造---工作笔记005
    查看>>
    No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-loadbalanc
    查看>>
    No mapping found for HTTP request with URI [/...] in DispatcherServlet with name ...的解决方法
    查看>>
    No mapping found for HTTP request with URI [/logout.do] in DispatcherServlet with name 'springmvc'
    查看>>
    No module named 'crispy_forms'等使用pycharm开发
    查看>>
    No module named cv2
    查看>>
    No module named tensorboard.main在安装tensorboardX的时候遇到的问题
    查看>>
    No module named ‘MySQLdb‘错误解决No module named ‘MySQLdb‘错误解决
    查看>>
    No new migrations found. Your system is up-to-date.
    查看>>
    No qualifying bean of type XXX found for dependency XXX.
    查看>>
    No qualifying bean of type ‘com.netflix.discovery.AbstractDiscoveryClientOptionalArgs<?>‘ available
    查看>>
    No resource identifier found for attribute 'srcCompat' in package的解决办法
    查看>>
    no session found for current thread
    查看>>
    No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
    查看>>
    NO.23 ZenTaoPHP目录结构
    查看>>
    no1
    查看>>
    NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
    查看>>