欢迎访问我的GitHub

https://github.com/zq2599/blog_demos

内容:所有原创文章分类汇总及配套源码,涉及Java、Docker、Kubernetes、DevOPS等;

关于Jaeger开发系列(java版)

  • 本文属于《Jaeger开发系列》,是第一篇,该系列是欣宸原创,旨在通过实战演练与Java程序员一起熟练掌握Jaeger相关的技术,使之在分布式系统中发挥巨作用;
  • 全系列由浅入深、从基本功能到深度定制都会涉及,希望这个系列能伴随您一同成长,为您提供一些及时的参考;

本篇概览

  • 作为《Jaeger开发系列》的开篇,咱们先花一分钟了解Jaeger的基本概念,再用三十秒时间完成部署,然后三十秒体验基本功能,以最轻松的姿势和心情开启Java程序员的Jaeger之旅;
  • 以下是我这里执行本篇实战的环境和软件:
  1. 电脑:MacBook Pro,macOS Big Sur (11.5.2)---您也可以使用Linux,如Ubuntu或者CentOS
  2. Docker:20.10.7
  3. JDK:8u301
  • 接下来先从Jaeger的基本概念开始吧;

关于Jaeger

  • Jaeger是一套开源的分布式调用链跟踪方案,由Uber创建,后来捐赠给CNCF(云原生计算基金会),官网地址:https://www.jaegertracing.io/

  • Jaeger的后端、Web端、本地库等都遵守了OpenTracing standard

  • 在OpenTracing标准中,一个工作的逻辑单元被称为span,它有自己的名称、开始时间、时长、标签等特性,如下图:

  • 下面是官方给出的Jaeger架构图(这是没有使用kafka做缓冲的版本),最上层一行表明Jaeger支持的语言类型,可见应用使用了SDK后,业务的span被送到jaeger-agent(通过UDP协议),然后被推送到jaeger-collector,数据被jaeger-collector写入数据库(DB),这样,用户通过浏览器访问jaeger-query,就能看到详细的调用链追踪结果了,另外,红色虚线是控制信号(例如采样相关的参数):

关于本次体验

  • 今天的体验环境由以下内容构成,有个名为jaeger-service-provider的web应用,其web接口被访问时,它会操作redis,然后将本次服务的数据上报到Jaeger,然后咱们就可以在Jaeger上看到本次服务的详细情况了:

极速部署jaeger体验环境

  • 请确保您的docker-compose功能可以正常使用

  • 创建文件docker-compose.yml,内容如下:

version: '3.0'

networks:
jaeger-tutorials-net:
driver: bridge
ipam:
config:
- subnet: 192.168.1.0/24
gateway: 192.168.1.1 services:
jaeger:
image: jaegertracing/all-in-one:1.26
container_name: jaeger
#选择网络
networks:
- jaeger-tutorials-net
#选择端口
ports:
- 16686:16686/tcp
restart: always
redis:
image: redis:6.2.5
container_name: redis
#选择网络
networks:
- jaeger-tutorials-net
restart: always
jaeger-service-provider:
image: bolingcavalry/jaeger-service-provider:0.0.1
container_name: jaeger-service-provider
#选择端口
ports:
- 8088:8080/tcp
#选择网络
networks:
- jaeger-tutorials-net
restart: always
  • 在docker-compose.yml所在目录执行命令docker-compose up -d,会立即开始下载三个镜像,然后启动服务:
Creating network "jaeger-service-provider_jaeger-tutorials-net" with driver "bridge"
Creating jaeger ... done
Creating jaeger-service-provider ... done
Creating redis ... done
  • 至此,jaeger体验环境已经部署完毕,咱们来体验吧

体验jaeger功能

  • 用浏览器访问:http://localhost:16686/search ,映入眼帘的Jaeger页面如下,熟悉golang的同学都清楚图标意味着什么(对于欣宸这样的Java铁粉,多想看到那里是一杯热咖啡啊...):

  • 从前面的架构图得知,jaeger-query就是当前页面的server服务,它自己也通过Jaeger上报了自身被使用的情况,如下图所示,终于见到了trace和span:

  • 接下来可以调用咱们部署的服务了,浏览器访问:http://localhost:8088/hello ,正常情况下收到返回的时间戳:

  • 再刷新Jaeger的页面,如下图所示,咱们的服务和trace名称都赫然在列,看来上报数据生效了,点击下图右上角红框中的圆点:

  • 点击那个红点后,进入对应trace的详情页,如下图:

  • 至此,咱们完成了Jaeger的入门知识学习和实际体验,如果您对内部的实现细节感兴趣,敬请期待接下来的开发实战揭秘,欣宸原创,必不辜负您

环境信息

  • 最后附上《Jaeger开发系列》所需的环境和版本信息,这样的版本搭配能正常运行,供您参考:
  1. 电脑:MacBook Pro,macOS Big Sur (11.5.2)
  2. Docker:20.10.7
  3. JDK:8u301
  4. Jaeger:1.26
  5. opentracing-spring-jaeger-cloud-starter:3.3.1
  6. Spring Boot:2.4.2
  7. Spring Cloud:2020.0.1
  8. Redis:6.2.5

你不孤单,欣宸原创一路相伴

  1. Java系列
  2. Spring系列
  3. Docker系列
  4. kubernetes系列
  5. 数据库+中间件系列
  6. DevOps系列

欢迎关注公众号:程序员欣宸

微信搜索「程序员欣宸」,我是欣宸,期待与您一同畅游Java世界...

https://github.com/zq2599/blog_demos

分布式调用链跟踪工具Jaeger?两分钟极速体验的更多相关文章

  1. 部署你的分布式调用链跟踪框架skywalking

    使用docker-compose 一键部署你的分布式调用链跟踪框架skywalking https://www.cnblogs.com/huangxincheng/p/9666930.html 一旦你 ...

  2. 使用docker-compose 一键部署你的分布式调用链跟踪框架skywalking

    一旦你的程序docker化之后,你会遇到各种问题,比如原来采用的本地记日志的方式就不再方便了,虽然你可以挂载到宿主机,但你使用 --scale 的话,会导致 记录日志异常,所以最好的方式还是要做日志中 ...

  3. istio分布式调用链Jaeger

    1.安装 kubectl apply -n istio-system -f https://raw.githubusercontent.com/jaegertracing/jaeger-kuberne ...

  4. idou老师教你学Istio 22 : 如何用istio实现调用链跟踪

    大家都知道istio可以帮助我们实现灰度发布.流量监控.流量治理等一些功能. 每一个功能都帮助我们在不同场景中实现不同的业务.那么其中比如流量监控这种复杂的功能Istio是如何让我们在不同的应用中实现 ...

  5. 三分钟极速体验:Java版人脸检测

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  6. 调用链系列一、Zipkin架构介绍、Springboot集承(springmvc,HttpClient)调用链跟踪、Zipkin UI详解

    1.Zipkin是什么 Zipkin分布式跟踪系统:它可以帮助收集时间数据,解决在microservice架构下的延迟问题:它管理这些数据的收集和查找:Zipkin的设计是基于谷歌的Google Da ...

  7. Spring Cloud 微服务六:调用链跟踪Spring cloud sleuth +zipkin

    前言:随着微服务系统的增加,服务之间的调用关系变得会非常复杂,这给运维以及排查问题带来了很大的麻烦,这时服务调用监控就显得非常重要了.spring cloud sleuth实现了对分布式服务的监控解决 ...

  8. spring cloud 学习(8) - sleuth & zipkin 调用链跟踪

    业务复杂的微服务架构中,往往服务之间的调用关系比较难梳理,一次http请求中,可能涉及到多个服务的调用(eg: service A -> service B -> service C... ...

  9. 前端人员必会工具-apipost两分钟上手(2分钟玩转apipost)

    本文通过简单介绍如何利用ApiPost调试接口和快速的生成接口文档,让您初步体验ApiPost的魅力! 1. API写完想要测试?试试模拟发送一次请求 新建接口,我想模拟发送请求如下 curl --l ...

随机推荐

  1. C#环境变量配置及csc命令详解(转自cy88310)

     C#环境变量设置步骤: 在桌面右击[我的电脑]->[属性]->[高级]->[环境变量] 在下面的系统变量栏点击"新建" 变量名输入"csc" ...

  2. 【Microsoft Azure 的1024种玩法】五、基于Azure Cloud Shell 一站式创建Linux VM

    [文章简介] Azure Cloud Shell 是一个用于管理 Azure 资源的.可通过浏览器访问的交互式经验证 shell. 它使用户能够灵活选择最适合自己工作方式的 shell 体验,无论是 ...

  3. [bzoj5418]屠龙勇士

    很显然,每一步所选的剑和怪物都是确定的,可以先求出来(不用写平衡树,直接用multiset即可,注意删除要删指针,以下假设第i次攻击用ki攻击的剑,攻击第i只怪)  首先判断无解,即如果存在ai使得g ...

  4. [luogu6702]Path

    维护每一个点到根路径的异或和(记作$d_{k}$),根据异或自反性,$(x,y)$的异或和即$d_{x}\oplus d_{y}$ 考虑两条路径的lca,选择其中深度较大的点,另一条路径必然在其子树外 ...

  5. 快读模板 + #define 压缩for

    快读是一个很重要的模板 #define 压缩for是为了代码的简洁 这里贴一下模板 #define f(i , a , b) for(int i=(a) ; i <= (b) ; i++) us ...

  6. 洛谷 P5224 - Candies(循环卷积)

    洛谷题面传送门 一道题解长度大概不到 1k 的题,可还是决定写篇题解,因为自己没有做出来( \(1004535809\) 好评( 首先这个 \(\equiv m\pmod{k}\) 有点把我们往单位根 ...

  7. Codeforces 288E - Polo the Penguin and Lucky Numbers(数位 dp+推式子)

    题目传送门 似乎我的解法和官方题解不太一样 纪念自己独立做出来的一道难度 2800 的题. 我们记 \(ans(x)\) 为 \([444...44,x]\) 的答案,显然答案为 \(ans(r)-a ...

  8. BZOJ 3238 差异

    BZOJ 3238 差异 看这个式子其实就是求任意两个后缀的 $ LCP $ 长度和.前面的 $ len(T_i)+len(T_j) $ 求和其实就是 $ n(n-1)(n+1)/2 $ ,这个是很好 ...

  9. PHP对称加密-AES加密、DES加密

    对称加密 对称加密算法是指,数据发信方将明文(原始数据)和密钥一起经过加密处理后,使其变成复杂的加密密文发送出去.收信方收到密文后,若要解读原文,则需要使用加密密钥及相关算法的逆算法对密文进行解密,使 ...

  10. (转载) Java多线程技术

    多线程编程一直是学员们比较头痛和心虚的地方,因为线程执行顺序的不可预知性和调试时候的困难,让不少人在面对多线程的情况下选择了逃避,采用单线程的方式,其实只要我们对线程有了明确的认识,再加上java内置 ...