分布式链路的一些主流方案对比

目前项目在从单体进化到了分布式架构以后,一个服务就会以多个副本的形式运行在不同的主机上,这样带来了性能和体验提升的同时,也为我们的开发运维同学带了一些痛点:

  • 故障或者业务层面的异常出现,如何快速发现和定位问题?
  • 服务之间相互依赖太多,如何判断一个点的问题对其他依赖服务的影响范围?
  • 如何在宏观角度上梳理各个服务之间的依赖及合理性?同时对拓扑链路性能的问题进行分析和解决?

面对这一系列的难题,学术界是给出了一个 OpenTracing 规范,它是一个轻量级的标准化层,它位于应用程序/类库和追踪或日志分析程序之间,详细介绍见 opentracing文档中文版。随着并发和异步成为现代软件应用的必然特性,分布式追踪系统成为有效监控的一个必须的组成部分。当然在落地的工业界内对此项技术还有一个别称:APM(Application Performance Management-应用性有管理),APM致力于监控和管理应用软件性能和可用性。通过监测和诊断复杂应用程序的性能问题,来保证软件应用程序的良好运行

对此,目前真正去落到实践应用,主要有主流的4种开源解决方案:

一、CAT

github地址:https://github.com/dianping/cat
大众点评开源贡献,基于Java开发的实时应用监控平台,包括实时应用监控,业务监控 。 集成方案是通过代码埋点的方式来实现监控,比如: 拦截器,注解,过滤器等。这样做有利有弊,好处是可以在自己需要的地方加埋点,比较有针对性;坏处是必须改动现有系统,很多开发团队不愿意,侵入性较强,集成成本较高,风险较大。

二、ZipKin

官网:http://zipkin.io/
github地址:https://github.com/openzipkin/zipkin
由Twitter团队开源, Zipkin是一个分布式的跟踪系统。Zipkin的java应用端是通过一个叫Brave的组件来实现对应用内部的性能分析数据采集。这个组件通过实现一系列的java拦截器,来做到对http/servlet请求、数据库访问的调用过程跟踪,然后通过在spring之类的配置文件里加入这些拦截器,完成对java应用的性能数据采集。

三、PinPoint

github地址:https://github.com/naver/pinpoint
由韩国团队naver团队开源,针对大规模分布式系统用链路监控,使用java写的工具。灵感来自短小精悍,帮助分析系统的总体结构和内部组件如何被调用在分布式应用提供了一个很好的解决方案。使用java探针字节码增加技术,实现对整个应用的监控 ,对应用零侵入。

四、SkyWalking

github地址:https://github.com/apache/skywalking
2015年由个人吴晟(华为开发者)开源 , 2017年加入Apache孵化器。针对分布式系统的应用性能监控系统,特别针对微服务、cloud native和容器化(Docker, Kubernetes, Mesos)架构, 其核心是个分布式追踪系统。使用java探针字节码增加技术,实现对整个应用的监控 。 对应用零侵入!

五、Open-Falcon

github地址:https://github.com/open-falcon/falcon-plus
小米开源的监控系统,文档资料齐全,针对性监控Mysql、Redis、MQ、Solr、及硬件监控,功能局限性较大,监控应用内部性能比较麻烦,无法查询异常日志,不支持搜索

参考引用:


1、分布式链路追踪系统深入理解
2、分布式链路追踪技术对比
3、分布式链路追踪技术对比

猿码道的专栏文章:
4、全链路监控(一):方案概述与比较
5、基于Java Instrument的Agent实现
6、JVMTI Agent 工作原理及核心源码分析
7、JVMTI Attach机制与核心源码分析

8、墨竹博主的专栏对Zipkin以及Brave有许多的讲述。
Java分布式跟踪系统Zipkin:初识Zipkin

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容