分布式调用链对比(pinpoint、skywalking、jaeger、zipkin等)

1. APM简述

    APM (Application Performance Management)是对企业的应用系统进行实时监控,它是用于实现对应用程序性能管理和故障管理的系统化的解决方案。

2.APM主要解决的问题:

  1. 集中式度量系统
  2. 分布式全链接追踪系统
  3. 集中式日志系统(elk)

......

3.分布式调用追踪(APM)一览

  1. Google的Drapper--未开源,最早的APM
  2. 阿里-鹰眼--未开源
  3. 大众点评——CAT--跨服务的跟踪功能与点评内部的RPC框架集成,这部分未开源且项目在2014.1已经停止维护。服务粒度的监控,通过代码埋点的方式来实现监控,比如: 拦截器,注解,过滤器等,对代码的侵入性较大,集成成本较高。
  4. Hydra-京东: 与dubbo框架集成,对于服务级别的跟踪统计,现有业务可以无缝接入。对于细粒度的兴趣点,需要业务人员手动添加。开源项目已于2013年6月停止维护
  5. PinPoint-naver,字节码探针技术,代码无侵入,体系完善不易修改,支持java,技术栈支持dubbo。其他语言社区支援中
  6. zipkin——java方便集成于springcloud,社区支持的插件也包括dubbo、rabbit、mysql、httpclient等(https://github.com/openzipkin/brave/tree/master/instrumentation),同时支持php、go、js等语言客户端,界面功能较为简单,本身无告警功能,可能需要二次开发。代码入侵度小。
  7. uber-jaeger, Jaeger支持java/c++/go/node/php,在界面上较为完善(对比zipkin),但是也无告警功能。代码入侵度小。dubbo目前无插件支持,可二次开发。
  8. skywalking ——华为,类似于PinPoint,目前还在apache孵化中,网上吞吐量对比中强于pinpoint,实际未验证。本身支持dubbo

4.方案对比

pinpoint

zipkin

jaeger

skywalking

OpenTracing兼容

客户端支持语言

java、php

java,c#,go,php等

java,c#,go,php等

Java, .NET Core, NodeJS and PHP

存储

hbase

ES,mysql,Cassandra,内存

ES,kafka,Cassandra,内存

ES,H2,mysql,TIDB,sharding sphere

传输协议支持

thrift

http、MQ

udp/http

gRPC

ui丰富程度

实现方式-代码侵入性

字节码注入,无侵入

拦截请求,侵入

拦截请求,侵入

字节码注入,无侵入

扩展性

trace查询

不支持

支持

支持

支持

告警支持

支持

不支持

不支持

支持

jvm监控

支持

不支持

不支持

支持

性能损失

5.各方案参考链接

    1.pinpoint-naver

    github: GitHub - pinpoint-apm/pinpoint: APM, (Application Performance Management) tool for large-scale distributed systems.

    docker快速体验:GitHub - pinpoint-apm/pinpoint-docker: Official Dockerized components of the Pinpoint

    2.zipkin-推特:

    github: GitHub - openzipkin/zipkin: Zipkin is a distributed tracing system

    页面详解:sleuth+zipkin ui界面详解(二)_sharedCode源码交流-CSDN博客_zipkin 界面

    zipkin于php对接:https://www.colabug.com/1872361.html

    3.jaeger-uber

    部分参考资料:

    jaeger简介,部署,入门实践 Uber jaeger--一个基于Go的分布式追踪系统 - 北极之北的个人空间 - OSCHINA - 中文开源技术交流社区

    jaeger——java实现 https://my.oschina.net/u/1789379/blog/1551421

    Uber分布式追踪系统Jaeger使用介绍和案例(PHP Hprose Go 跨语言调用)

    https://segmentfault.com/a/1190000011636957

    全链路监控Jaeger搭建实战 全链路监控Jaeger搭建实战 - 简书

    jaeger官网快速开始 Getting started — Jaeger documentation

    4.skywalking(推荐)

    github: GitHub - apache/skywalking: APM, Application Performance Monitoring System

    SkyWalking 分布式追踪系统 SkyWalking 分布式追踪系统 - 简书

    Apache SkyWalking 5.0中文版图文详解使用手册

    http://skywalking.apache.org/zh/blog/2018-12-18-Apache-SkyWalking-5-0-UserGuide.html

    skywalking学习笔记 skywalking学习笔记 - 掘金

6.参考资料

最近更新

  1. TCP协议是安全的吗?

    2024-01-03 10:46:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-03 10:46:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-03 10:46:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-03 10:46:01       18 阅读

热门阅读

  1. 2023.12.30力扣每日一题——一周中的第几天

    2024-01-03 10:46:01       43 阅读
  2. 牙科废水处理设备详细介绍

    2024-01-03 10:46:01       38 阅读
  3. C++汇编语言学习计划

    2024-01-03 10:46:01       39 阅读
  4. PDF最强处理工具-StirlingPDF

    2024-01-03 10:46:01       40 阅读
  5. Laya3d碰撞后退表现算法

    2024-01-03 10:46:01       42 阅读
  6. 5分钟带你解决Promise疑难杂症

    2024-01-03 10:46:01       34 阅读
  7. pytorch 转 onnx

    2024-01-03 10:46:01       32 阅读
  8. flask web学习之flask与http(四)

    2024-01-03 10:46:01       35 阅读
  9. torch.where用法介绍

    2024-01-03 10:46:01       37 阅读
  10. 构建一个动态时钟

    2024-01-03 10:46:01       34 阅读
  11. nginx,ssl,证书和校验

    2024-01-03 10:46:01       33 阅读
  12. FTP服务器安装、远程访问以及安全配置项

    2024-01-03 10:46:01       41 阅读
  13. 计算机网络---知识点

    2024-01-03 10:46:01       41 阅读