`
Swifie
  • 浏览: 11092 次
  • 性别: Icon_minigender_2
  • 来自: 广州
社区版块
存档分类
最新评论

SpringCloud:微服务利剑之APM平台(二)Pinpoint

 
阅读更多

1. Pinpoint概述

Pinpoint是一个由韩国人编写的为大型分布式系统服务的链路跟踪平台,并提供大量链路跟踪数据分析汇总解决方案。自2012年7月开始开发,与2015年1月做为一个开源项目推出。

2. Pinpoint主要特性

  • 分布式事务跟踪,跟踪跨分布式应用的消息。
  • 自动检测应用拓扑,帮助你搞清楚应用的架构。
  • 水平扩展以便支持大规模服务器集群。
  • 提供代码级别的可见性以便轻松定位失败点和瓶颈。
  • 使用字节码增强技术,添加新功能而无需修改代码。

3. Pinpoint优势

  • 无入侵:采用字节码增强技术,新增功能无需修改代码。
  • 性能高:对性能的影响非常小(资源使用量最小仅增加3%),异步数据传输,采用UDP协议让出网络连接优先级。

4. Pinpoint架构简介

先看一下官方提供的架构图,如图:

 

SpringCloud系列教程 | 第十六篇:微服务利剑之APM平台(二)Pinpoint
 

 

Pinpoint主要包含了4个组件:

  • Pinpoint Agent:探针,附加到用于分析的Java服务
  • Pinpoint Collector:数据收集组件,部署在Web容器上
  • Pinpoint Web UI:数据展示组件,部署在Web容器上
  • HBase Storage:数据存储组件

架构图从上往下看,首先是通过Agent组件收集需要的数据,通过UPD/TCP的方式将数据发送给Collector,由Collector将数据分析整理过后存入HBase,通过Web UI组件将分析好的数据从HBase中读出,展示在现代化的UI界面上。

5. Pinpoint数据结构简介

Pinpoint中,核心数据结构由Span, Trace, 和 TraceId组成。

  • Span: RPC (远程过程调用/remote procedure call)跟踪的基本单元; 当一个RPC调用到达时指示工作已经处理完成并包含跟踪数据。为了确保代码级别的可见性,Span拥有带SpanEvent标签的子结构作为数据结构。每个Span包含一个TraceId。
  • Trace: 多个Span的集合; 由关联的RPC (Spans)组成. 在同一个trace中的span共享相同的TransactionId。Trace通过SpanId和ParentSpanId整理为继承树结构.
  • TraceId: 由 TransactionId, SpanId, 和 ParentSpanId 组成的key的集合. TransactionId 指明消息ID,而SpanId 和 ParentSpanId 表示RPC的父-子关系。
    • TransactionId (TxId): 在分布式系统间单个事务发送/接收的消息的ID; 必须跨整个服务器集群做到全局唯一.
    • SpanId: 当收到RPC消息时处理的工作的ID; 在RPC请求到达节点时生成。
    • ParentSpanId (pSpanId): 发起RPC调用的父span的SpanId. 如果节点是事务的起点,这里将没有父span – 对于这种情况, 使用值-1来表示这个span是事务的根span。

6. Pinpoint版本依赖

  • Pinpoint所需要的Java版本兼容:
Pinpoint Version Agent Collector Web
1.0.x 6-8 6-8 6-8
1.1.x 6-8 7-8 7-8
1.5.x 6-8 7-8 7-8
1.6.x 6-8 7-8 7-8
1.7.x 6-8 8 8
1.8.0 6-10 8 8
1.8.1+ 6-11 8 8
  • HBase所需要的版本兼容
Pinpoint Version HBase 0.94.x HBase 0.98.x HBase 1.0.x HBase 1.2.x HBase 2.0.x
1.0.x yes no no no no
1.1.x no not tested yes not tested no
1.5.x no not tested yes not tested no
1.6.x no not tested not tested yes no
1.7.x no not tested not tested yes no
1.8.x no not tested not tested yes no
Pinpoint Version HBase 0.94.x HBase 0.98.x HBase 1.0.x HBase 1.2.x HBase 2.0.x
  • Agent – Collector所需要的版本兼容
Agent Version Collector 1.0.x Collector 1.1.x Collector 1.5.x Collector 1.6.x Collector 1.7.x Collector 1.8.x
1.0.x yes yes yes yes yes yes
1.1.x not tested yes yes yes yes yes
1.5.x no no yes yes yes yes
1.6.x no no not tested yes yes yes
1.7.x no no no no yes yes
1.8.x no no no no no yes
Agent Version Collector 1.0.x Collector 1.1.x Collector 1.5.x Collector 1.6.x Collector 1.7.x Collector 1.8.x
  • Flink所需要的版本兼容
Pinpoint Version flink 1.3.X flink 1.4.X flink 1.5.X flink 1.6.X flink 1.7.X Pinpoint Version
1.7.x yes yes no no no 1.7.x
1.8.x yes yes no no no 1.8.x
1.9.x yes yes yes yes yes 1.9.x
Pinpoint Version flink 1.3.X flink 1.4.X flink 1.5.X flink 1.6.X flink 1.7.X Pinpoint Version
1.7.x yes yes no no no 1.7.x
1.8.x yes yes no no no 1.8.x
1.9.x yes yes yes yes yes 1.9.x

7. Spring Cloud与Pinpoint实战

在介绍实战之前,我们先介绍一下Pinpoint部署构建。

笔者构建的一些前置条件:

java:1.8
CentOS:7.6

  1. HBase部署

存储方式需要使用HBase1.2.x的版本,笔者这里选择的是HBase1.2.6,下载地址为Apache官网,推荐使用有端点续传功能的下载器下载(实在是有点慢),HBase全版本下载地址:http://archive.apache.org/dist/hbase/ ,各位读者选择自己喜欢的版本下载。

下载完成后,将HBase1.2.6放入CentOS的opt目录中,执行如下命令:

Java代码  收藏代码
  1. tar -xvzf hbase-1.2.6-bin.tar.gz  
  2. mv hbase-1.2.6/ /data/service/hbase/  

 修改hbase中config目录中的JAVA_HOME,将这里的JAVA_HOME修改为自己本地的路径,笔者这里修改如下:

Java代码  收藏代码
  1. export JAVA_HOME=/opt/jdk1.8.0_221  

 修改完成后就可以进入hbase的bin目录,启动hbase了,执行如下语句:

Java代码  收藏代码
  1. ./start-hbase.sh  

 启动成功后,可以执行jps,如果看到有HMaster,可有证明启动成功,如下:

Java代码  收藏代码
  1. 19263 HMaster  

 也可以打开浏览器访问:http://ip:16010/master-status ,结果如图:

 

SpringCloud系列教程 | 第十六篇:微服务利剑之APM平台(二)Pinpoint
 

 

接下来我们先把Pinpoint的HBase的构建脚本导入,进入HBase的bin目录下执行如下语句:

Java代码  收藏代码
  1. ./hbase shell /opt/hbase-create.hbase  

 数据导入成功我们在HBase的UI界面上可以看到,如图:

 

SpringCloud系列教程 | 第十六篇:微服务利剑之APM平台(二)Pinpoint
 

 

后面的目录是笔者用来存放HBase初始化脚本的路径,各位读者可根据情况自行替换,至此,HBase环境准备完成,接下来开始部署Collector和Web UI。

  1. Collector和Web UI部署

出于简单方便考虑,不推荐初学者自行编译代码进行部署,可以直接使用官方提供的发行版本进行部署。

浏览器访问链接:https://github.com/naver/pinpoint/releases/ ,直接下载当前最新Release版本即可,笔者现在看到的最新版本是1.8.4,如图,需要下载的内容有pinpoint-agent-1.8.4.tar.gzpinpoint-collector-1.8.4.warpinpoint-web-1.8.4.war

 

SpringCloud系列教程 | 第十六篇:微服务利剑之APM平台(二)Pinpoint
 

 

首先需要准备两个tomcat,笔者这里下载的tomcat8,解压两份后并重命名为apache-tomcat-pinpoint-collectorapache-tomcat-pinpoint-web

apache-tomcat-pinpoint-collector中的config中的server.xml进行修改。

将8005改成18005,8080改成18080,8443改为18443,8009改为18009。

同样也将apache-tomcat-pinpoint-web中的config中的server.xml进行修改。

将8005改成28005,8080改成28080,8443改为28443,8009改为28009。

apache-tomcat-pinpoint-collector中的webapp/ROOT清空,将pinpoint-collector-1.8.4.war放入并解压。解压完成后就可以进入bin目录使用./startup.sh启动tomcat了,并且使用命令tail -f ../logs/catalina.out观察启动日志是否启动成功。

同样,将apache-tomcat-pinpoint-web中的webapp/ROOT清空,将pinpoint-web-1.8.4.war放入并解压。解压完成后就可以进入bin目录使用./startup.sh启动tomcat了,并且使用命令tail -f ../logs/catalina.out观察启动日志是否启动成功。

当Collector和Web UI都启动成功后,就可以使用打开浏览器访问:http://ip:28080/#/main ,初次访问如图:

 

SpringCloud系列教程 | 第十六篇:微服务利剑之APM平台(二)Pinpoint
 

 

  1. Agent启用

实战案例,本实战案例和上一篇实战案例保持一致,同样是4个服务,包括Zuul-Service、Eureka-Service、Consumer-Service和Provider-Service。具体实现代码本章不再列出,各位读者可以参考上一篇或者Github仓库(https://github.com/meteor1993/SpringCloudLearning/tree/master/chapter15),下面我们介绍Spring Cloud是如何与Pinpoint整合使用的。

接入方式和上一篇的Skywalking是一致的,都是使用探针技术接入应用程序,java -jar的方式来加载Agent探针。

首先在工程的跟目录中执行mvn install,而后在CentOS的opt中新建4个目录,分别存放4个打好包的工程。笔者这里创建的4个目录分别为/opt/project/consumer_service/opt/project/eureka_service/opt/project/provider_service/opt/project/zuul_service,将4个jar包分别放入对应的目录中,并解压刚才我们下载好的pinpoint-agent-1.8.4.tar.gz探针,我们将解压后的探针放在/opt的目录中,接下来,我们使用如下命令,顺次启动4个jar包:

Java代码  收藏代码
  1. java -javaagent:/opt/pinpoint-bootstrap-1.8.4.jar -Dpinpoint.agentId=consumer-service -Dpinpoint.applicationName=consumer-server -jar /opt/project/consumer_service/consumer-0.0.1-SNAPSHOT.jar  
  2.   
  3. java -javaagent:/opt/pinpoint-bootstrap-1.8.4.jar -Dpinpoint.agentId=eureka-service -Dpinpoint.applicationName=eureka-server -jar /opt/project/eureka_service/eureka-0.0.1-SNAPSHOT.jar  
  4.   
  5. java -javaagent:/opt/pinpoint-bootstrap-1.8.4.jar -Dpinpoint.agentId=provider-service -Dpinpoint.applicationName=provider-server -jar /opt/project/provider_service/provider-0.0.1-SNAPSHOT.jar  
  6.   
  7. java -javaagent:/opt/pinpoint-bootstrap-1.8.4.jar -Dpinpoint.agentId=zuul-service -Dpinpoint.applicationName=zuul-server -jar /opt/project/zuul_service/zuul-0.0.1-SNAPSHOT.jar  

 上述命令执行完成之后,再打开Web UI查看显示情况。

首先打开浏览器访问:http://192.168.44.129:8080/client/hello?name=spring ,页面正常显示Hello, name is spring,查看Pinpoint的Web UI,如图:

 

SpringCloud系列教程 | 第十六篇:微服务利剑之APM平台(二)Pinpoint
 

 

图清楚的显示了我们当前系统的拓扑结构,横线上面的数字代表了调用次数,右边部分,最上面显示的是成功和失败的情况,中间部分显示的是响应时间,下面显示的是加载所使用的时间。

检查器(Inspector):这里已Zuul-Service为例,Timeline显示的是请求的时间段,Information显示的是节点的一些当前信息,包含Application Name、Agent Id、Agent版本、JVM信息、开始时间等。

Heap信息的使用情况,如图:

 

SpringCloud系列教程 | 第十六篇:微服务利剑之APM平台(二)Pinpoint
 

 

系统CPU、活动线程、响应时间等信息如图:

 

SpringCloud系列教程 | 第十六篇:微服务利剑之APM平台(二)Pinpoint
 

 

更多Pinpoint的信息,读者可以通过官方Demo(http://125.209.240.10:10123/#/main )或者自行构建试验来查看结果,这里不再一一赘述。至此,Spring Cloud和Pinpoint的使用介绍也就完成了。更多有关Pinpoint的信息各位读者可以前往Github的官网进行查阅,地址为:https://github.com/naver/pinpoint 。

8. 小结

这里总结一下整个案例的启动顺序:

  1. 启动HBase
  2. 启动collector
  3. 启动Web-UI
  4. 启动Agent(Eureka、provider、consumer、zuul)
  5. 应用调用
  6. 访问Web-UI查看统计信息

同Skywalking一样,以上启动顺序供各位读者参考,请各位读者最好按照以上顺序启动,因为不同的组件之前其实是有相互依赖关系的,如果随意更改启动顺序可能会造成某些未知问题。至此,Spring Cloud和APM的相关操作就告一段落了。APM可以很好的帮我们理解系统行为,也是分析系统性能的工具,更是发生问题故障的时候利器,可以帮我们快速的定位查找问题。

分享到:
评论

相关推荐

    基于 JFinal 的国产微服务框架,SpringCloud 之外的另一个选择

    JFinal 是一款基于 Java 的高性能 MVC 框架,它以简单、实用为设计原则,致力于提供快速开发体验。...通过了解和掌握 Jboot,开发者可以在不依赖 SpringCloud 的情况下,构建出高性能、高可扩展性的微服务体系。

    Pinpoint 2.0.X版本

    二、pinpoint-web:可视化监控平台 pinpoint-web是Pinpoint的前端展示部分,提供了丰富的图表和报表,用于直观地展示系统的健康状况。用户可以查看服务的调用拓扑图,追踪单个请求的完整路径,监控服务的性能指标,...

    pinpoint二次开发.pptx

    Pinpoint 二次开发指南 Pinpoint 是一个开源的 APM(Application Performance Management/应用性能管理)工具,基于字节码...Pinpoint 是一个功能强大且灵活的 APM 工具,其二次开发可以满足不同企业的个性化需求。

    271760513/pinpoint:2.3.3 pinpoint 探针使用

    pinpoint 探针,docker镜像 271760513/pinpoint:2.3.3 使用

    Centos下分布式跟踪工具Pinpoint的完整部署记录(个人精华版本)

    Pinpoint能够帮助开发者监控微服务架构中的应用性能,通过追踪调用链路,提供详细的请求延迟和调用关系信息。以下是完整的部署步骤: 1. **系统准备**: 在开始部署前,确保你的CentOS系统已经更新到最新,并安装...

    基于spring boot微服务学习pdf

    微服务设计.pdf;微服务架构.pptx;快速搭建Spring Boot.docx;spring-boot-reference-guide-zh.pdf;springboot.docx;leaning-pinpoint.pdf

    《Pinpoint & Pinpoint C Agent(支持PHP) 简易安装文档》

    Pinpoint是一款开源的应用程序性能监控工具(APM),主要用于分布式系统的监控,尤其是针对微服务架构下的应用程序。它能够帮助开发者快速地识别和解决性能瓶颈问题。Pinpoint不仅提供了丰富的可视化界面,还可以...

    pinpoint分布式系统APM工具

    Pinpoint是一款对Java编写的大规模分布式系统的APM工具,有些人也喜欢称呼这类工具为调用链系统、分布式跟踪系统。我们知道,前端向后台发起一个查询请求,后台服务可能要调用多个服务,每个服务可能又会调用其它...

    java7源码-pinpoint:查明

    pinpoint-docker docker-compose pull docker-compose up -d 服务端容器 pinpoint-web pinpoint服务器ui界面 入口:ip:8079 pinpoint-collector pinpoint数据收集器 收集客户端数据 pinpoint-hbase pinpoint数据...

    pinpoint-collector-1.6.2.tar.gz

    Pinpoint作为一个强大的Java APM(Application Performance Management)工具,提供了全面的应用性能监控解决方案。本文将深入探讨Pinpoint Collector 1.6.2版本,它在收集、统计和分析pinpoint-web获取的数据方面...

    SpringCloud可视化链路追踪系统Zipkin部署过程

    SpringCloud 可视化链路追踪系统 Zipkin 部署过程 本文主要介绍了 SpringCloud 可视化链路追踪系统 Zipkin 部署过程,并提供了详细的示例代码,对大家的学习或者工作具有一定的参考学习价值。 什么是 Zipkin? ...

    使用Myeclipse部署Pinpoint项目

    Pinpoint是一款专为大规模分布式系统设计的应用性能管理(APM)工具。它主要适用于基于Java的应用程序,能够帮助开发者追踪整个请求的调用链路,并收集各服务节点上的性能数据。这有助于在复杂的分布式环境中快速...

    第三步-pinpoint-搭建pinpoint.zip

    Pinpoint是一个针对大规模分布式系统的APM(Application Performance Monitoring)工具,它提供了丰富的服务调用链、性能指标和问题定位功能。通过Pinpoint,开发者可以清晰地了解系统内部的服务关系,监控服务的...

    pinpoint-agent-2.0.4.tar.gz

    Pinpoint 是一个强大的分布式追踪系统,专为大型分布式应用程序设计,尤其在微服务架构中,它提供了全面的性能监控和问题诊断能力。 Pinpoint-Agent-2.0.4.tar.gz 是该系统的特定版本,用于安装和配置在目标服务器上...

    pinpoint安装部署、监控tomcat、weblogic、webSphere手册

    Pinpoint 是一款开源的应用性能管理(Application Performance Management, APM)工具,适用于基于 Java 的大规模分布式系统。它通过在应用程序启动时安装 agent 实现监控,无需对代码进行任何修改,能够最大限度地...

    Pinpoint是大规模分布式系统的一个应用性能管理工具

    《Pinpoint:大规模分布式系统的应用性能管理利器》 在当今的互联网时代,大规模分布式系统已经成为了企业业务发展的基石。为了确保这些复杂系统的高效稳定运行,应用性能管理(Application Performance Management...

    pinpoint安装部署手册

    ### Pinpoint 安装部署手册知识点详述 #### 一、环境准备 ##### 1.1 部署环境约定 - **HBase服务器**: - IP地址:192.168.233.136 - Hostname:hbase - **Pinpoint服务器**: - IP地址:192.168.233.138 - ...

    PinPoint使用教程 Pinpoint是用Java编写的大型分布式系统的APM

    Pinpoint是用Java编写的大型分布式系统的APM(Application Performance Management应用程序性能管理)工具,Pinpoint 通过跟踪分布式应用之间的调用来提供解决方案,以帮助分析系统的总体结构和内部模块之间如何相互...

    pinpoint 中文使用文档,供大家学习

    Pinpoint是一款开源的APM(应用性能管理)工具,主要面向基于Java的大型分布式系统,其设计思路受到了Google Dapper论文的启发。Pinpoint通过跟踪分布式应用间的调用,帮助开发者分析系统总体结构以及内部各模块间的...

    开源社区的微服务生态体系.pptx

    7. **API Gateway**:如Zuul、Spring Cloud Gateway等,作为微服务架构的入口,提供路由、过滤等功能。 微服务架构对比传统的Java模块化方案(如OSGi、Jigsaw),其本质区别在于强调服务的独立部署和边界清晰,通过...

Global site tag (gtag.js) - Google Analytics