写点什么

分布式链路追踪 Jaeger + 微服务 Pig 在 Rainbond 上的实践分享

  • 2022 年 8 月 04 日
  • 本文字数:1952 字

    阅读完需:约 6 分钟

分布式链路追踪Jaeger + 微服务Pig在Rainbond上的实践分享

随着微服务架构的流行,客户端发起的一次请求可能需要涉及到多个或 N 个服务,致使我们对服务之间的监控和排查变得更加复杂。


举个例子:

某条业务线的某个接口调用服务端时快时慢,这时就需要排查各个服务的日志进行分析,调动各个服务的开发人员联动排查,这种排查费时又费力。对于 ToB 的业务有时候还拿不到日志,难搞哦!


因此,就需要可以帮助理解系统行为、用于分析性能问题的工具,以便发生故障的时候,能够快速定位和解决问题,那就是 APM (Application Performance Monitor)。目前流行的 APM 开源工具有很多,比如:Zipkin,Skywalking,Pinpoint、Jaeger 等等,本文将主要介绍 Jaeger 。


Jaeger 是 Uber 技术团队发布的开源分布式跟踪系统,它用于监控和故障排查基于微服务的分布式系统:

  • 分布式上下文传播、事务监控

  • 根本原因、服务依赖分析

  • 性能/延迟优化

  • OpenTracing 启发的数据模型

  • 多个存储后端:Cassandra, Elasticsearch, memory.

  • 系统拓扑图

  • 服务性能监控(SPM)

  • 自适应采样

Jaeger 架构



如何在 Rainbond 上集成?



1.集成 OpenTelemetry Client:

v1.36 版本以前 Jaeger Client 是基于OpenTracingAPI 实现的客户端库,Jaeger Client 结合 Jaeger Agent 一起使用,发送 span 到 Jaeger Collector。


v1.36 版本以后被弃用。使用 OpenTelemetry 替代 Jaeger Client and Jaeger Agent,详情见 Jaeger and OpenTelemetry


OpenTelemetry 是无侵入的,只需在 Java 进程启动时添加javaagent,例:java-javaagent:path/to/opentelemetry-javaagent.jar-jar myapp.jar 。


那么在 Rainbond 上就可以通过插件将OpenTelemetryjavaagent 下载到组件中并修改启动命令。


2.连接到 Jaeger-Collector:

将所有安装了OpenTelemetryjavaagent 插件的微服务组件都通过依赖连接到JaegerCollector

实践步骤

实践中将使用 Spring Cloud Pig 进行演示,Gitee:https://gitee.com/zhangbigqi/pig

Rainbond 部署请参阅文档 快速安装 。

1. Spring Cloud Pig 源码部署

通过源码部署SpringCloudPig 微服务框架就不详细介绍部署了,请参阅:

2. OpenTelemetry 插件安装

从应用商店安装opentelemetry-java-agent 初始化插件,该插件的作用是下载opentelemetry-javaagent.jar 到微服务组件内,可以在 Java 启动项中指定。

  • 团队视图 -> 插件 -> 从应用商店安装插件 -> 搜索opentelemetry-java-agent 并安装。



3. 部署 Jaeger

在开源应用商店中搜索Jaeger 并安装到指定应用中。



4. OpenTelemetry Agent 插件配置

1.开通 OpenTelemetry Agent 插件

pig-gateway 为例,在组件 -> 插件中开通opentelemetry-java-agent 插件并更新组件生效,微服务内的其他组件均需要开通插件并更新或重启组件生效。



2.配置环境变量

为所有微服务组件配置环境变量。

可使用应用配置组 统一配置并应用到所有组件中。



3.配置组件服务名称

为所有微服务组件配置环境变量OTEL_SERVICE_NAME ,配置组件的 Jaeger 服务名称,如:OTEL_SERVICE_NAME=pig-gatewayOTEL_SERVICE_NAME=pig-auth

5.建立依赖关系

将所有微服务组件添加依赖连接到JaegerCollector 。


Jaeger 部署在另外一个应用,需要进入 组件 -> 依赖 -> 添加JaegerCollector 依赖,就可以在当前应用的拓扑图看到JaegerCollector 组件,剩下的组件都可通过拓扑图编辑模式进行依赖连接。更新或重启所有微服务组件使依赖关系生效。



6. Jaeger 快速使用

  1. 访问 Spring Cloud Pig UI 进行登录,使其产生数据。

  2. 访问Jaeger-Query 的16686 端口,打开对外服务即可访问JaegerUI 。

  3. 在 Jaeger Search 页面中搜索微服务 Pig-gateway 的 Traces

  • Service:选择微服务的组件

  • Operation:选择操作类型,例:GET POST、接口、类.....

  • Tags:根据响应头筛选,例:http.status_code=200 error=true

  • Lookback:选择时间

  • Max Duration:最大持续时间;Min Duration:最小持续时间。

  • Limit Results:限制返回结果数量。



  1. 找到 Pig-gateway HTTP POST 的 Traces 并包含了 pig-auth Span 并进入,可看到很清晰的展示了服务之间一层一层的调用以及接口的响应时间,这样我们就可以排查到底是哪个服务调用的慢或者调用有问题。



Jaeger 拓扑图生成

拓扑图默认不会生成,使用spark-dependencies 组件生成拓扑图数据,这是一个 Spark 作业,它从存储中收集 span,分析服务之间的链接,并将它们存储起来以供以后在 UI 中展示。请参阅 Jaeger Spark dependencies

spark-dependencies 组件占用资源较大,不使用时可关闭,需要生成拓扑图数据时将其启动即可。



最后

有了 APM 系统后,使我们可以更好的分析业务性能、排查故障等。

结合 Rainbond 作为基座不管是SpringCloud还是Jaeger 或其他APM 都可以很方便、快捷的部署使用,从繁琐的部署、配置中解放出来,让我们更多的关注于业务层。

发布于: 刚刚阅读数: 5
用户头像

Rainbond 2018.11.08 加入

Rainbond 是一个云原生应用管理平台,使用简单,不需要懂容器、Kubernetes和底层复杂技术,支持管理多个Kubernetes集群,和管理企业应用全生命周期。

评论

发布
暂无评论
分布式链路追踪Jaeger + 微服务Pig在Rainbond上的实践分享_开源_北京好雨科技有限公司_InfoQ写作社区