빠른 액세스 pinpoint1.8.3는 분산 시스템 가이드

에 대해 핀 포인트

HTTPS : 핀 포인트 추적 도구는 호출 체인, 최신 버전은 1.8.5이며, 공식 GitHub의 주소입니다 //github.com/naver/pinpoint

전투 분산 환경으로 설계

오늘의 전투는 처음 두 SpringBoot 응용 프로그램뿐만 아니라, MySQL은, 레디 스, 플러스 서버 배포 핀 포인트, 다음 표에 사용 된 다섯 기계의 총이있다, 간단한 분산 환경을 준비합니다 :

호스트 이름 IP 주소 효과
핀 끝 192.168.121.148 핀 포인트 서비스는 기계를 배포
서비스-A 192.168.121.146 두 개의 인터페이스를 제공합니다
1. 추가 : MySQL의에 레코드를 추가, 그리고 인터페이스 서비스-b는 설정 호출
2. GET : MySQL의에서 찾을 수없는 경우, 데이터를 찾기 위해 서비스 나 인터페이스에 대한 호출을받을
서비스-B 192.168.121.147 : 그것은 두 개의 인터페이스 제공
1. GET : 레디 스에서 지정된 레코드를 찾기
2 세트 : 레디 스 데이터를 기록, 30 초 기간
MySQL은 192.168.121.143 MySQL의 서비스 여기서 기계
반복 192.168.121.144 레디 스 서비스 어디 기계

아래와 같이 전체 구조 :
그림 삽입 설명 여기
자세한 내용은 더 많은 응용 프로그램을 참조 "전투 즉시 사용할 소스 (springboot + 레디 스 + MyBatis로 + restTemplate )"

소스 GitHub의 이러한 서비스는 데모 프로젝트, 주소, 다음 표에서 링크 정보의 완전한 소스 코드를 다운로드 할 수 GitHub의에서 직접 다운로드 할 수 있습니다 :

이름 링크
프로젝트 홈 https://github.com/zq2599/blog_demos GitHub의에 프로젝트의 홈 페이지
자식 저장소 주소 (HTTPS) https://github.com/zq2599/blog_demos.git 该项目源码的仓库地址,https协议
git仓库地址(ssh) [email protected]:zq2599/blog_demos.git 该项目源码的仓库地址,ssh协议

这个git项目中有多个文件夹,本章的应用在pinpoint185demo文件夹下,如下图红框所示:
그림 삽입 설명 여기

配置host

为了后续配置方便,将以下内容写入上述五台电脑的/etc/hosts文件中,这样所有的配置文件都可以用hostname来表示了:

192.168.121.143 mysql
192.168.121.144 redis
192.168.121.146 service-a
192.168.121.147 service-b
192.168.121.148 pinpoint

版本信息参考

  1. 操作系统:CentOS Linux release 7.7.1908
  2. docker:Community 19.03.2
  3. docker-compose:1.24.1
  4. springboot:2.0.5.RELEASE
  5. mysql:5.7.27
  6. redis:5.0.6

部署pinpoint

  1. 登录pinpoint主机;
  2. 装好docker和docker-comose,可以参考《一行命令安装docker和docker-compose(CentOS7)》
  3. 装好git客户端:yum install git -y
  4. 执行以下命令会先下载材料再按照docker-compose.yml的编排启动所有容器:
git clone https://github.com/naver/pinpoint-docker.git; \
git checkout 1.8.5; \
cd pinpoint-docker; \
docker-compose pull && docker-compose up -d

控制台提示如下:

[root@pinpoint ~]# clear
[root@pinpoint ~]# git clone https://github.com/naver/pinpoint-docker.git; \
> cd pinpoint-docker; \
> git checkout 1.8.5; \
> docker-compose pull && docker-compose up -d
正克隆到 'pinpoint-docker'...
remote: Enumerating objects: 34, done.
remote: Counting objects: 100% (34/34), done.
remote: Compressing objects: 100% (33/33), done.
remote: Total 384 (delta 6), reused 13 (delta 1), pack-reused 350
接收对象中: 100% (384/384), 244.12 MiB | 1.72 MiB/s, done.
处理 delta 中: 100% (185/185), done.
Note: checking out '1.8.5'.

You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by performing another checkout.

If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -b with the checkout command again. Example:

  git checkout -b new_branch_name

HEAD 目前位于 39b9e1e... [naver/pinpoint#5998] update for release 1.8.5
Pulling jobmanager          ... done
Pulling zoo2                ... done
Pulling taskmanager         ... done
Pulling zoo1                ... done
Pulling zoo3                ... done
Pulling pinpoint-mysql      ... done
Pulling pinpoint-hbase      ... done
Pulling pinpoint-web        ... done
Pulling pinpoint-collector  ... done
Pulling pinpoint-agent      ... done
Pulling pinpoint-quickstart ... done
Creating network "pinpoint-docker_pinpoint" with driver "bridge"
Creating volume "pinpoint-docker_data-volume" with default driver
Creating volume "pinpoint-docker_mysql_data" with default driver
Creating pinpoint-flink-jobmanager ... done
Creating pinpoint-docker_zoo3_1     ... done
Creating pinpoint-docker_zoo1_1    ... done
Creating pinpoint-docker_zoo2_1     ... done
Creating pinpoint-hbase             ... done
Creating pinpoint-mysql             ... done
Creating pinpoint-flink-taskmanager ... done
Creating pinpoint-web               ... done
Creating pinpoint-collector         ... done
Creating pinpoint-agent             ... done
Creating pinpoint-quickstart        ... done

此处由于要下载大量文件,并且还要下载docker镜像,因此建议您耐心等待
5. 启动完成后,执行命令docker ps -f name=pinpoint-web查看web服务的端口,如下图红框所示,是宿主机的8079端口:
그림 삽입 설명 여기
6. 访问地址http://192.168.121.148:8079 ,即可进入pinpoint的监控页面,如下图,已经自带了一个demo应用,该应用是在docker-compose.yml中配置的:
그림 삽입 설명 여기
pinpoint服务端已经准备好了,接下来我们将SpringBoot应用接入pinpoint,达到监控和调用链跟踪的效果

SpringBoot应用接入pinpoint(service-a)

接下来要在SpringBoot应用所在机器上做操作,将应用接入pinpoint;

  1. 下载pinpoint agent包,地址是:https://github.com/naver/pinpoint/releases ,要下载的文件如下图红框所示:
    그림 삽입 설명 여기
  2. 登录service-a应用所在机器,在/root目录下新建文件夹pinpoint-agent-1.8.5
  3. 将刚才下载的pinpoint-agent-1.8.5.tar.gz文件放入/root/pinpoint-agent-1.8.5目录,然后再解压pinpoint-agent-1.8.5.tar.gz(注意,是先放入pinpoint-agent-1.8.5文件夹再解压);
  4. 打开文件/root/pinpoint-agent-1.8.5/pinpoint.config,找到profiler.collector.ip、profiler.tomcat.conditional.transform、profiler.applicationservertype这三个配置,修改成以下的值:
profiler.collector.ip=pinpoint
profiler.tomcat.conditional.transform=false
profiler.applicationservertype=SPRING_BOOT
  1. 重新启动service-a服务,假设原有的启动命令是java -jar service-a-1.0-SNAPSHOT.jar,现在改为:
java -jar \
-javaagent:/root/pinpoint-agent-1.8.5/pinpoint-bootstrap-1.8.5.jar \
-Dpinpoint.agentId=192.168.121.146 \
-Dpinpoint.applicationName=service-a \
service-a-1.0-SNAPSHOT.jar

如上所述,一共增加了三个参数:

参数名 作用
javaagent 指定pinpoint-agent所在位置
Dpinpoint.applicationName 上报到pinpoint后,在页面上展示的应用名称
Dpinpoint.agentId 代表当前机器信息的标签,这里填写的是IP地址,当有多个service-a进程接入pinpoint时,要用这个标签来区分

SpringBoot应用接入pinpoint(service-b)

service-b的配置方式和service-a的一样,注意启动参数要改成service-b有关的,以下是service-b的启动命令:

java -jar \
-javaagent:/root/pinpoint-agent-1.8.5/pinpoint-bootstrap-1.8.5.jar \
-Dpinpoint.agentId=192.168.121.147 \
-Dpinpoint.applicationName=service-b \
service-b-1.0-SNAPSHOT.jar

制造一些请求,用于观测数据

  1. 接下来制造一些请求,让service-a和service-b执行业务代码,我这里用的是Postman,它提供了自动发起重复请求的功能,如下图:
    그림 삽입 설명 여기
  2. 接下来打开Runner Window,如下图:
    그림 삽입 설명 여기
  3. 按照下图进行设置,即可向service-a持续发起请求:
    그림 삽입 설명 여기

pinpoint的监控功能

  1. 打开pinpoint页面,可以看到service-a、service-b的监控数据已经有了:
    그림 삽입 설명 여기
  2. 用鼠标对右上角的请求量进行框选,可以查看请求的详情:
    그림 삽입 설명 여기
  3. 如下图,可以详细的看到每个请求内部的执行情况:
    그림 삽입 설명 여기
  4. 또한 기계는 전체 상황을 관찰 할 수있다 :
    그림 삽입 설명 여기
    이 시점에서, 일반적인 자바 실제 pinpoint1.8.3 당신이 핀 포인트보기를 통해 시스템을 모니터링하기 위해 호출 체인 상황을 고려하는 경우, 이것은 당신에게 약간을 줄 수있는 희망, 완료 시스템 액세스를 배포 참조;

실제 과정을 통해 다음과 같은 구덩이가 건너 유의하시기 바랍니다 :

  1. 각 방화벽 시스템을 닫습니다;
  2. 닫기 스왑은 기계를 정확하게;
게시 된 328 개 원래 기사 · 원 찬양 946 · 조회수 1,170,000 +

추천

출처blog.csdn.net/boling_cavalry/article/details/102011341