Jaeger为何物?

Jaeger 是Uber推出的一款开源分布式追踪系统,兼容OpenTracing API。分布式追踪系统用于记录请求范围内的信息。例如,一次远程方法调用的执行过程和耗时。是我们排查系统问题和系统性能的利器。

分布式追踪系统种类繁多,但是核心步骤有三个:代码埋点,数据存储和查询展示。

以上几句描述都是我copy的,所以大家想要对Jaeger有更加深入的了解,可以参阅这篇文章Jaeger 分布式追踪系统模块分析,能让你对Jaeger有一个简单的认识。

当然我们还要记得APM的三大模块分别是集中式日志系统,集中式度量系统和分布式全链接追踪系统。

而Jaeger属于的就是追踪系统,度量系统我们则会使用prometheus,日志系统一般则是elk。

选用Jaeger的原因

一个是它兼容OpenTracing API,写起来简单方便,一个是UI相较于Zipkin的更加直观和丰富,还有一个则是sdk比较丰富,go语言编写,上传采用的是udp传输,效率高速度快。

相比

搭建

测试搭建

在个人使用或者测试上,Jaeger的搭建其实较为简单,因为我们使用的存储方式是内存化的,所以我们可以直接使用官方给我们打包好的镜像。

docker run -d -e COLLECTOR_ZIPKIN_HTTP_PORT=9411 -p5775:5775/udp -p6831:6831/udp -p6832:6832/udp \

-p5778:5778 -p16686:16686 -p14268:14268 -p9411:9411 jaegertracing/all-in-one:latest

线上搭建

线上搭建我采用的是jaeger搭配elasticsearch,效果还不错,而且搭配起来比较简单,官方给的方式是jaeger搭cassandra,不过我试了下没有搭起来。。。。。这是官方的地址jaeger-docker-compose.yml,下面是我采用的搭建yml

version: '2.1'

services:

elasticsearch:

image: elasticsearch:5.6.4

environment:

- "ES_JAVA_OPTS=-Xms1024m -Xmx1024m"

collector:

image: jaegertracing/jaeger-collector

environment:

- SPAN_STORAGE_TYPE=elasticsearch

- ES_SERVER_URLS=http://elasticsearch:9200

- ES_USERNAME=elastic

- LOG_LEVEL=debug

depends_on:

- elasticsearch

agent:

image: jaegertracing/jaeger-agent

environment:

- COLLECTOR_HOST_PORT=collector:14267

- LOG_LEVEL=debug

ports:

- "5775:5775/udp"

- "5778:5778"

- "6831:6831/udp"

- "6832:6832/udp"

depends_on:

- collector

query:

image: jaegertracing/jaeger-query

environment:

- SPAN_STORAGE_TYPE=elasticsearch

- ES_SERVER_URLS=http://elasticsearch:9200

- ES_USERNAME=elastic

- LOG_LEVEL=debug

ports:

- 16686:16686

depends_on:

- elasticsearch

hotrod:

image: jaegertracing/example-hotrod:1.6

command: all --jaeger-agent.host-port=agent:6831

ports:

- 8080:8080

depends_on:

- agent

这里面除了hotrod以外都是必须的,hotrod是用来测试我们搭建后是否能成功上传到我们的agent的。

这里要注意的一点是,虽然有depends_on,但是由于elasticsearch启动的原因,导致query, collector连不上直接挂掉,agent虽然没挂但是也连不上,所以我们需要手动重启query,collector,agent,这个时候再查看应该是都正常启动了。

jaeger

测试 (地址应该是http://127.0.0.1:8080)

进入到hotrod,随便点击一个按钮,生成调用传到agent

hotrod

查看我们的query

如果是本地就是这个地址http://127.0.0.1:16686

query

query2

可以看到,Jaeger的UI还是非常直观,友好,漂亮的。

sdk 接入

目前官方提供了Java,Python,Go,C++,Node.js。sdk,

php暂时只有第三方的,我现在使用的是php这个sdk,还不错,可以扩展开发,我基于这个sdk写了一个swoft框架的jaeger组件,默认支持mysql,redis,httpClient监控,并且可灵活添加header,如果有需要,可以使用,地址:swoft-jaeger

最后

无论是什么样的监控系统,对于线上服务都或多或少都有性能损耗,所以在线上一定要采样处理才是最佳使用方式,当然,我的组件支持采样咯。

jaeger php,全链路监控Jaeger搭建实战相关推荐

  1. 全链路监控Jaeger

    全链路监控Jaeger 目录 全链路监控Jaeger Jaeger为何物? 分布式追踪系统核心步骤 Jaeger系统 Jagger优点 Jaeger架构 Jaeger组件介绍 Span Jaeger特 ...

  2. istio 实战 六 全链路监控 - Jaeger

    系列文章 istio 实战 一 Kubernetes 中快速搭建 istio istio 实战 二 bookinfo 部署 istio 实战 三 智能路由 istio 实战 四 权重路由以及监控 is ...

  3. 星尘分布式全链路监控 Newlife.Stardust 搭建实例

    星尘分布式全链路监控看起来功能挺强大的,但是网上都是官方的介绍,直接调用的demo相对比较少,期间踩坑比较多,希望对后面的人有所帮助 1.https://github.com/NewLifeX/Sta ...

  4. 牛逼哄哄的全链路监控系统!搭建起来也没有想象中的那么难啊...

    点击关注公众号,回复"1024"获取2TB学习资源! 问题背景 随着微服务架构的流行,服务按照不同的维度进行拆分,一次请求往往需要涉及到多个服务.互联网应用构建在不同的软件模块集上 ...

  5. 阿里巴巴山猎:手把手教你玩转全链路监控

    作者:山猎@阿里巴巴 排版:大白 全文12000字 读完需要 30 分钟 速读仅需 5 分钟 1 前言 随着分布式技术的发展与演进,微服务技术成为了大型分布式IT架构的必然选择.从本质上来讲,微服务是 ...

  6. PinPoint分布式全链路监控

    PinPoint分布式全链路监控 安装需要的所有包下载路径: 链接: https://pan.baidu.com/s/1sl9dP9r 密码: jsux 介绍: PinPoint是一个开源的APM(( ...

  7. AI时代的全链路监控,阿里工程师怎么做?

    阿里妹导读:全链路监控从业务的视角出发,监控整个业务流程的健康状况,无需多个系统切换,直观看到全局和上下游,方便快速发现.定位问题.今天,我们一起来看看阿里基础设施技术团队在这方面的实践经验. 背景 ...

  8. AI时代的全链路监控(阿里)

    全链路监控从业务的视角出发,监控整个业务流程的健康状况,无需多个系统切换,直观看到全局和上下游,方便快速发现.定位问题.今天,我们一起来看看阿里基础设施技术团队在这方面的实践经验. 背景 近年来,随着 ...

  9. 一文带你入坑全链路监控,skywalking

    一,APM概念介绍 APM(Application Performance Management)对应用程序性能和可用性的监控管理系统.它主要有这三个方面的内容,分别是 Logs(日志). Trace ...

最新文章

  1. linux 6.4 图形界面,为CentOS 6.4安装图形界面并用VNC远程连接
  2. 一个完整的操作UI线程的例子,用到了多种方式
  3. C语言 用代码将10进制转换为2进制表示
  4. 通过挂载系统光盘搭建本地yum仓库的方法
  5. 主流微服务注册中心浅析和对比
  6. STM32H743+CubeMX-串口非空闲中断接收
  7. Windows文本文件编码
  8. Chrome 无法抓取跳转请求的解决办法
  9. python 程序化交易名单_2020 Python程序化交易高级实战班 - 优量在线 - 学量化投资,到优量在线 - Powered By EduSoho...
  10. 前端基础知识总结 (三)
  11. 怎么解决服务器延迟问题
  12. 项目部署后的域名配置
  13. 光电子学教材 马养武
  14. 第十四届蓝桥杯省赛C/C++研究生组试题及答案分享
  15. 换友情链接时候是换Http的还是Https的好?
  16. 企业数字化转型组织人才发展建设
  17. Ubuntu20.04 使用Python实现全过程离线语音识别(包含语音唤醒,语音转文字,指令识别,文字转语音)
  18. HR软件切忌过度招标
  19. 红象云腾CRH 一键部署大数据平台
  20. 江苏无锡英语口语测试软件,无锡公共英语三级口试

热门文章

  1. 0004-python第三天:基本数据类型
  2. 为docker容器设置独立ip
  3. R中ifelse、which、%in%的用法
  4. Zephyr启动过程与中断响应
  5. 如何通过TXT文件批量生成EAN14条码
  6. 【数据挖掘】 kmeans聚类算法的原理与实现 (使用matlab)
  7. c语言程序设计文件操作题库,C语言程序设计文件操作.doc
  8. 程序员的目标不是赚钱而是向牛人看齐(转)
  9. Raw NAND FLASH原理及ONFI接口标准
  10. 视频分析(MATLAB)——MV分镜头图像分类