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

2024-01-02 14:52

本文主要是介绍分布式调用链对比(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.参考资料

  • 分布式链路追踪技术对比 分布式链路追踪技术对比_moonpure的专栏-CSDN博客_链路追踪对比
  • 回到网易后开源 APM 技术选型与实战 回到网易后开源APM技术选型与实战-InfoQ
  • zipkin vs jaeger 滑动验证页面
  • 调用链选型之Zipkin,Pinpoint,SkyWalking,CAT 调用链选型之Zipkin,Pinpoint,SkyWalking,CAT - 简书

这篇关于分布式调用链对比(pinpoint、skywalking、jaeger、zipkin等)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/562780

相关文章

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口

集中式版本控制与分布式版本控制——Git 学习笔记01

什么是版本控制 如果你用 Microsoft Word 写过东西,那你八成会有这样的经历: 想删除一段文字,又怕将来这段文字有用,怎么办呢?有一个办法,先把当前文件“另存为”一个文件,然后继续改,改到某个程度,再“另存为”一个文件。就这样改着、存着……最后你的 Word 文档变成了这样: 过了几天,你想找回被删除的文字,但是已经记不清保存在哪个文件了,只能挨个去找。真麻烦,眼睛都花了。看

【LabVIEW学习篇 - 21】:DLL与API的调用

文章目录 DLL与API调用DLLAPIDLL的调用 DLL与API调用 LabVIEW虽然已经足够强大,但不同的语言在不同领域都有着自己的优势,为了强强联合,LabVIEW提供了强大的外部程序接口能力,包括DLL、CIN(C语言接口)、ActiveX、.NET、MATLAB等等。通过DLL可以使用户很方便地调用C、C++、C#、VB等编程语言写的程序以及windows自带的大

开源分布式数据库中间件

转自:https://www.csdn.net/article/2015-07-16/2825228 MyCat:开源分布式数据库中间件 为什么需要MyCat? 虽然云计算时代,传统数据库存在着先天性的弊端,但是NoSQL数据库又无法将其替代。如果传统数据易于扩展,可切分,就可以避免单机(单库)的性能缺陷。 MyCat的目标就是:低成本地将现有的单机数据库和应用平滑迁移到“云”端

string字符会调用new分配堆内存吗

gcc的string默认大小是32个字节,字符串小于等于15直接保存在栈上,超过之后才会使用new分配。

laravel框架实现redis分布式集群原理

在app/config/database.php中配置如下: 'redis' => array('cluster' => true,'default' => array('host' => '172.21.107.247','port' => 6379,),'redis1' => array('host' => '172.21.107.248','port' => 6379,),) 其中cl

京东物流查询|开发者调用API接口实现

快递聚合查询的优势 1、高效整合多种快递信息。2、实时动态更新。3、自动化管理流程。 聚合国内外1500家快递公司的物流信息查询服务,使用API接口查询京东物流的便捷步骤,首先选择专业的数据平台的快递API接口:物流快递查询API接口-单号查询API - 探数数据 以下示例是参考的示例代码: import requestsurl = "http://api.tanshuapi.com/a

基于MySQL实现的分布式锁

概述 在单机时代,虽然不需要分布式锁,但也面临过类似的问题,只不过在单机的情况下,如果有多个线程要同时访问某个共享资源的时候,我们可以采用线程间加锁的机制,即当某个线程获取到这个资源后,就立即对这个资源进行加锁,当使用完资源之后,再解锁,其它线程就可以接着使用了。例如,在JAVA中,甚至专门提供了一些处理锁机制的一些API(synchronize/Lock等)。 但是到了分布式系统的时代,这种

类的load方法和initialize方法对比

1. load方法在main()之前被调用,而initialize方法在main()之后调用 load方法实际是在load_images过程中被调用的。load_images会将当前应用依赖的所有镜像(动态库)加载到内存,在在加载中首先是对镜像进行扫描,将所有包含 load 方法的类加入列表 loadable_classes ,然后从这个列表中逐一调用其所包含的 load 方法。 +[XXCl