基于Pinpoint对SpringCloud微服务项目实现全链路监控的问题
目录
- 1.全链路监控的概念
- 2.pinpoint链路监控组件的介绍
- 3.使用docker部署pinpoint监控组件
- 4.在微服务中集成pinpoint-agent
- 4.1.pinpoint-agent的接入方式
- 4.2.配置pinpoint-agent
- 4.3.修改每个微服务程序的Dockerfile接入pinpoint-agent
- 4.4.先将product商品服务接入到pinpoint观察效果
- 4.5.将所有的微服务接入到pinpoint系统
- 5.pinpoint监控系统简单使用
- 5.1.查看程序代码类之间是怎么调用其他微服务的
- 5.2.查看微服务的JVM监控信息
1.全链路监控的概念 随着微服务架构的流行,服务按照不同的纬度进行拆分,一次请求往往需要设计到多个微服务程序,这些服务可能使用不同的编程语言开发,不同的团队开发,可能部署很多歌副本,因此就需要一些可以帮助理解系统行为,用于分析性能问题的工具,以便发生故障的时候,能够快速定位和解决问题,这个工具就是全链路监控组件。
全链路监控组件可以监控每个微服务程序之间通信的一个数据指标,可以帮助运维好很好的分析一个请求时如何转发到各个微服务之间以及微服务之间的调度。
全链路性能监控,从整体纬度到局部纬度展示各项指标,将跨应用的所有调度链性能信息几种展现,方便度量整体和局部的性能,并且方面找到故障产生的源头,生产上可以极大缩短故障的排除时间。
全链路监控解决的问题:
- 请求链路追踪
- 调用情况衡量
- 容器规划参考
- 运行情况反馈
全链路监控工具有很多种,应该从下面几种方面去选择
- 探针的性能消耗
- 代码的侵入性
- 监控纬度
- 可扩展性
主流的链路监控工具由zipkin、skywalking、pinpoint。
2.pinpoint链路监控组件的介绍 pinpoint是一个APM(应用程序性能管理)的工具,适用于JAVA/PHP编写的大型分布式系统。
pinpoint的特性:
- 服务地图(serverMap):通过可视化分布式系统的模块和他们之间的相互来展示系统拓扑,点击某个节点会展示该模块的详情,比如当前的状态和请求数量。
- 实时活动性线程图(Realtime Active Thread Chart):实时监控应用内部的活动线程。
- 请求响应分布图(Request/Response Scatter Chart):长期可视化请求数量和应答模式来定位潜在问题。
- 调用栈(CallStack):在分布式环境中为每个调用生成代码级别的可视图,在单个视图中定位瓶颈和失败点检查器(Inspector):查看应用上的其他详细信息,比如CPU使用率、内存/垃圾回收、TPS和JVM参数。
pinpoint agent会部署在程序服务器上,程序启动时会指定agent服务,由pinpoint collector获取微服务之间的链路监控,然后存储在Hbase数据库中,pinpoint web ui展示监控数据。
文章图片
3.使用docker部署pinpoint监控组件 pinpoint托管在github上,拉取镜像非常慢,可以从百度网盘上获取。
pinpoint对docker-compose的版本也要要求,最好在1.25版本以上。
1.下载docker-compose# curl -L https://github.com/docker/compose/releases/download/1.25.0/docker-compose-Linux-x86_64 -o /usr/local/bin/docker-compose # chmod a+x /usr/local/bin/docker-compose 2.下载pinpoint docker部署安装包# wget https://codeload.github.com/pinpoint-apm/pinpoint-docker/zip/refs/tags/1.8.53.部署pinpoint# unzip pinpoint-docker-1.8.5.zip# docker-compose pull && docker-compose up -d4.如果网速不行,就采用下载的方式部署#导入pinpoint镜像[root@binary-k8s-node2 ~]# cd pinpoint-image/[root@binary-k8s-node2 pinpoint-image]# for i in `ls`; do docker load -i $i; done#部署pinpoint[root@binary-k8s-node2 ~]# unzip pinpoint-docker-1.8.5.zip >/dev/null[root@binary-k8s-node2 ~]# cd pinpoint-docker-1.8.5/[root@binary-k8s-node2 pinpoint-docker-1.8.5]# docker-compose up -dCreating pinpoint-docker-185_zoo2_1 ... doneCreating pinpoint-flink-jobmanager... doneCreating pinpoint-docker-185_zoo1_1 ... doneCreating pinpoint-hbase... doneCreating pinpoint-mysql... doneCreating pinpoint-docker-185_zoo3_1 ... doneCreating pinpoint-flink-taskmanager ... doneCreating pinpoint-collector... doneCreating pinpoint-web... doneCreating pinpoint-agent... doneCreating pinpoint-quickstart... done[root@binary-k8s-node2 pinpoint-docker-1.8.5]# docker-compose ps
文章图片
pinpoint-web容器提供页面展示,已经将容器的8080端口映射成了8039端口,直接访问8079端口即可。
pinpoint自带了一个quickapp的展示模板
文章图片
4.在微服务中集成pinpoint-agent
4.1.pinpoint-agent的接入方式
Tomcat方式接入pinpoint-agent方式需要修改bin/catalina.sh脚本CATALINA_OPTS="$CATALINA_OPTS -javaagent:"$AGENT_PATH/pinpoint-bootstrap-$VERSION.jar"CATALINA_OPTS="$CATALINA_OPTS -Dpinpoint.agentId="$AGENT_ID"CATALINA_OPTS="$CATALINA_OPTS -Dpinpoint.applicationName="$APPLICATION_NAME"java -jar启动程序的方式如下直接在启动命令中增加即可java -jar -javaagent:$AGENT_PATH/pinpoint-bootstrap-$VERSION.jar -Dpinpoint.agentId=$AGENT_ID-Dpinpoint.applicationName=$APPLICATION_NAME xxx.jar-javaagent:$AGENT_PATH/pinpoint-bootstrap-$VERSION.jar#agent程序的的jar包-Dpinpoint.agentId=$AGENT_ID#程序计入pinpoint的一个id号,每个微服务副本节点都要求唯一-Dpinpoint.applicationName=$APPLICATION_NAME#应用组名,一个相同的微服务他们的应用组名要保持一样
下载pinpoint-agent程序
点击设置—>installation
https://github.com/pinpoint-apm/pinpoint/releases/download/1.8.5/pinpoint-agent-1.8.5.tar.gz
文章图片
4.2.配置pinpoint-agent
配置pinpoint-agent,然后将pinpoint-agent目录拷贝到每一个微服务的程序代码目录中。
1.下载pinpoint-agent[root@binary-k8s-master1 ~]# wget https://github.com/pinpoint-apm/pinpoint/releases/download/1.8.5/pinpoint-agent-1.8.5.tar.gz2.配置pinpoint[root@binary-k8s-master1 ~]# vim pinpoint-agent/pinpoint.config profiler.collector.ip=192.168.20.13#指定pinpoint collector组件的IP地址3.将pinpoint拷贝到每个微服务的代码目录中[root@binary-k8s-master1 ~]# cp -rp pinpoint-agent springcloud/simple-microservice-dev1/{eureka-service,gateway-service,portal-service}[root@binary-k8s-master1 ~]# cp -rp pinpoint-agent springcloud/simple-microservice-dev1/product-service/product-service-biz/[root@binary-k8s-master1 ~]# cp -rp pinp springcloud/simple-microservice-dev1/stock-service/stock-service-biz/[root@binary-k8s-master1 ~]# cp -rp pinpoint-agent springcloud/simple-microservice-dev1/stock-service/stock-service-biz/
4.3.修改每个微服务程序的Dockerfile接入pinpoint-agent
修改每个微服务程序的Dockerfile,将pinpoint的程序目录拷贝到容器中,然后在程序的启动命令中加上pinpoint-agent参数,接入pinpoint,其中
-Dpinpoint.agentId
字段的值采用pod的名称来定义,Dpinpoint.applicationName
字段的值采用simple-服务名称来定义。eureke-service服务
[root@binary-k8s-master1 simple-microservice-dev1]# vim eureka-service/Dockerfile FROM 192.168.20.11/base/centos-java:v1RUN mkdir /data/simple-microservice/eureka-service -pCOPY ./target/eureka-service.jar /data/simple-microservice/eureka-service/COPY pinpoint-agent /pinpoint-agentRUN echo -e "#!/bin/bash \njava -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=\${HOSTNAME} -Dpinpoint.applicationName=simple-eureka -Deureka.instance.hostname=${MY_POD_NAME}.eureka-service.simple-ms /data/simple-microservice/eureka-service/eureka-service.jar > /data/simple-microservice/eureka-service/eureka-service.log & \ntail -f /data/simple-microservice/eureka-service/eureka-service.log" > /data/entrypoint.sh && chmod a+x /data/entrypoint.shEXPOSE 8080ENTRYPOINT /data/entrypoint.sh############################################java -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=${HOSTNAME} -Dpinpoint.applicationName=simple-eureka -Deureka.instance.hostname=${MY_POD_NAME}.eureka-service.simple-ms /data/simple-microservice/eureka-service/eureka-service.jar
gateway-service服务
[root@binary-k8s-master1 simple-microservice-dev1]# vim gateway-service/Dockerfile FROM 192.168.20.11/base/centos-java:v1RUN mkdir /data/simple-microservice/gateway-service -pCOPY ./target/gateway-service.jar /data/simple-microservice/gateway-service/COPY pinpoint-agent /pinpoint-agentRUN echo -e "#!/bin/bash \njava -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=\${HOSTNAME} -Dpinpoint.applicationName=simple-gateway /data/simple-microservice/gateway-service/gateway-service.jar > /data/simple-microservice/gateway-service/gateway-service.log & \ntail -f /data/simple-microservice/gateway-service/gateway-service.log" > /data/entrypoint.sh && chmod a+x /data/entrypoint.shEXPOSE 8080ENTRYPOINT /data/entrypoint.sh############################################java -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=${HOSTNAME} -Dpinpoint.applicationName=simple-gateway /data/simple-microservice/gateway-service/gateway-service.jar
order-service服务
[root@binary-k8s-master1 simple-microservice-dev1]# vim order-service/order-service-biz/Dockerfile FROM 192.168.20.11/base/centos-java:v1RUN mkdir /data/simple-microservice/order-service -pCOPY ./target/order-service-biz.jar /data/simple-microservice/order-service/COPY pinpoint-agent /pinpoint-agentRUN echo -e "#!/bin/bash \njava -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=\${HOSTNAME} -Dpinpoint.applicationName=simple-order/data/simple-microservice/order-service/order-service-biz.jar > /data/simple-microservice/order-service/order-service-biz.log & \ntail -f /data/simple-microservice/order-service/order-service-biz.log" > /data/entrypoint.sh && chmod a+x /data/entrypoint.shEXPOSE 8080ENTRYPOINT /data/entrypoint.sh############################################java -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=${HOSTNAME} -Dpinpoint.applicationName=simple-order/data/simple-microservice/order-service/order-service-biz.jar
portal-service服务
[root@binary-k8s-master1 simple-microservice-dev1]# vim portal-service/Dockerfile FROM 192.168.20.11/base/centos-java:v1RUN mkdir /data/simple-microservice/portal-service -pCOPY ./target/portal-service.jar /data/simple-microservice/portal-service/COPY pinpoint-agent /pinpoint-agentRUN echo -e "#!/bin/bash \njava -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=\${HOSTNAME} -Dpinpoint.applicationName=simple-portal /data/simple-microservice/portal-service/portal-service.jar > /data/simple-microservice/portal-service/portal-service.log & \ntail -f /data/simple-microservice/portal-service/portal-service.log" > /data/entrypoint.sh && chmod a+x /data/entrypoint.shEXPOSE 8080ENTRYPOINT /data/entrypoint.sh############################################java -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=${HOSTNAME} -Dpinpoint.applicationName=simple-protal /data/simple-microservice/portal-service/portal-service.jar
product-service服务
[root@binary-k8s-master1 simple-microservice-dev1]# vim product-service/product-service-biz/Dockerfile FROM 192.168.20.11/base/centos-java:v1RUN mkdir /data/simple-microservice/product-service -pCOPY ./target/product-service-biz.jar /data/simple-microservice/product-service/COPY pinpoint-agent /pinpoint-agentRUN echo -e "#!/bin/bash \njava -jar -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=\${HOSTNAME} -Dpinpoint.applicationName=simple-product /data/simple-microservice/product-service/product-service-biz.jar > /data/simple-microservice/product-service/product-service-biz.log & \ntail -f /data/simple-microservice/product-service/product-service-biz.log" > /data/entrypoint.sh && chmod a+x /data/entrypoint.shEXPOSE 8080ENTRYPOINT /data/entrypoint.sh############################################java -jar -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=${HOSTNAME} -Dpinpoint.applicationName=simple-product /data/simple-microservice/product-service/product-service-biz.jar
stock-service服务
[root@binary-k8s-master1 simple-microservice-dev1]# vim stock-service/stock-service-biz/Dockerfile FROM 192.168.20.11/base/centos-java:v1RUN mkdir /data/simple-microservice/stock-service -pCOPY ./target/stock-service-biz.jar /data/simple-microservice/stock-service/COPY pinpoint-agent /pinpoint-agentRUN echo -e "#!/bin/bash \njava -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=\${HOSTNAME} -Dpinpoint.applicationName=simple-stock /data/simple-microservice/stock-service/stock-service-biz.jar > /data/simple-microservice/stock-service/stock-service-biz.log & \ntail -f /data/simple-microservice/stock-service/stock-service-biz.log" > /data/entrypoint.sh && chmod a+x /data/entrypoint.shEXPOSE 8080ENTRYPOINT /data/entrypoint.shjava -jar -javaagent:/pinpoint-agent/pinpoint-bootstrap-1.8.5.jar -Dpinpoint.agentId=${HOSTNAME} -Dpinpoint.applicationName=simple-stock /data/simple-microservice/stock-service/stock-service-biz.jar
4.4.先将product商品服务接入到pinpoint观察效果
我们接入pinpoint的Dockerfile已经写好,直接使用脚本将produce重新部署一下即可。
sh deploy_k8s.sh product-service[root@binary-k8s-master1 k8s]# kubectl get pod -n simple-msNAMEREADYSTATUSRESTARTSAGEeureka-01/1Running16d17heureka-11/1Running06d17heureka-21/1Running16d17hgateway-7bb79fdbc4-vvnct1/1Running06d11horder-6694f4c474-rg7kw1/1Running06d17hportal-697fdf95dd-ml86k1/1Running06d16hproduct-847bb6d9fc-cs6921/1Running010m#重新部署stock-6cf98bb445-l8gxb1/1Running06d19h
product部署好之后在portal门户网站上购买一个商品,产生product商品微服务的请求,观察pinpoint上的链路状态。
product商品微服务下单之后会调用stock库存微服务,stock微服务还没有接入到pinpoint中,所以在看pinpoint上链路监控时,就会发现stock只会以ip的形式展示。
可以在链路监控视图中看到服务之间调用请求的次数,以及是如何调用的。
文章图片
4.5.将所有的微服务接入到pinpoint系统
Dockerfile已经调整好,只需要执行咱们写好的部署脚本,将所有的微服务根据最新的Dockerfile制作出最新的镜像,然后在K8S集群中重新部署一下即可。
deploy_k8s脚本不跟任何位置参数就表示将所有的微服务程序全部更新部署。
[root@binary-k8s-master1 k8s]# sh deploy_k8s.sh
在门户网站中购买两个商品观察微服务之间的调用。
文章图片
5.pinpoint监控系统简单使用 在监控视图的右侧可以选择不同的微服务副本节点、程序之间的调用、请求成功失败的次数
文章图片
5.1.查看程序代码类之间是怎么调用其他微服务的
1)点击view servers可以随机切换各个副本节点
文章图片
2)点击右侧最上面的统计图,然后找到图中的小点,选中这个小点就会跳转到代码调用的页面
文章图片
3)选中完之后会立即跳转,然后点击该请求
请求成功的监控内容
文章图片
请求失败的监控内容
文章图片
4)这里还会有比之前更丰富的视图
文章图片
5)点击mixed view会看到更加丰富的展示视图
请求成功的
文章图片
请求失败的
文章图片
5.2.查看微服务的JVM监控信息
1)点击inspector
文章图片
2)选择指定的副本节点
这些名称都是通过在启动命令中加的
-Dpinpoint.agentId=${HOSTNAME}
参数生效的文章图片
【基于Pinpoint对SpringCloud微服务项目实现全链路监控的问题】到此这篇关于基于Pinpoint对SpringCloud微服务项目实现全链路监控的文章就介绍到这了,更多相关Pinpoint全链路监控内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 基于SpringMVC实现网页登录拦截
- XML 、DTD以及YAML的解释、对比
- 扩展我们的分析处理服务(Smartly.io)(使用|扩展我们的分析处理服务(Smartly.io):使用 Citus 对 PostgreSQL 数据库进行分片)
- 基于Three.js制作一个3D中国地图
- Java实现解析ini文件对应到JavaBean中
- ECMAScript|js中对象和数组的浅拷贝与深拷贝(ES6、前端面试常用)
- Java毕设项目|基于JavaScript+html5的家教小程序的设计与实现
- pandas|pandas 对日期类型数据的处理
- 对求职面试者的一点小建议
- 基于Kubernetes/K8S构建Jenkins持续集成平台(下)