中介軟體---分散式跟蹤---Pinpoint
本文初衷
因為工作需要,這周研究了一下APM(Application Performance Management)相關技術,看了些許資料,對比了各種技術的特點,最終選擇Pinpoint作為效能監控工具,本文的主要目的是記錄本人部署Pinpoint的過程。
Pinpoint是什麼
簡單的說,Pinpoint是一款對Java編寫的大規模分散式系統的APM工具,有些人也喜歡稱呼這類工具為呼叫鏈系統
、分散式跟蹤系統
。我們知道,前端向後臺發起一個查詢請求,後臺服務可能要呼叫多個服務,每個服務可能又會呼叫其它服務,最終將結果返回,彙總到頁面上。如果某個環節發生異常,工程師很難準確定位這個問題到底是由哪個服務呼叫造成的,Pinpoint等相關工具的作用就是追蹤每個請求的完整呼叫鏈路,收集呼叫鏈路上每個服務的效能資料,方便工程師能夠快速定位問題。
同類工具
為什麼要用Pinpoint
最重要的原因,對程式碼的零侵入,運用JavaAgent位元組碼增強技術,只需要加啟動引數即可。
Pinpoint架構圖
(圖片出處:官網)架構說明:
- Pinpoint-Collector:收集各種效能資料
- Pinpoint-Agent:和自己執行的應用關聯起來的探針
- Pinpoint-Web:將收集到的資料顯示成WEB網頁形式
- HBase Storage:收集到的資料存到HBase中
開始部署
前提條件
- maven 3.2.x+
- git
- java 6+
0. 開始
- 下載:git clone https://github.com/naver/pinpoint.git
- 進入Pinpoint目錄後編譯:mvn install -Dmaven.test.skip=true
- 如果不想自己手動打包,則可以在這裡直接下載打包好的。下載
1. 部署Hbase
Pinpoint以Hbase作為資料的儲存。
- 下載Hbase:http://apache.mirror.cdnetworks.com/hbase/
- 解壓後編輯:
conf/hbase-env.sh,
新增JAVA_HOME配置:,在27行左右:
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_121.jdk/Contents/Home
- 編輯hbase-site.xml:
<configuration> <property> <name>hbase.rootdir</name> <value>file:///Users/acheron/Tmp/hbase</value> </property> <property> <name>hbase.zookeeper.property.dataDir</name> <value>/Users/acheron/Tmp/zookeeper</value> </property> <property> <name>hbase.zookeeper.property.clientPort</name> <value>2182</value> </property> </configuration>
這樣配置是本地單例項模式啟動,上面配置分別表示:資料存放地點、zookeeper資料存放地點、zookeeper埠號(預設2181)。當然這個檔案可以不配置,那麼會採取預設值。
啟動hbase的時候,hbase用得是自帶的zk,在hbase的配置裡可見 export HBASE_MANAGES_ZK=true;
- 進入hbase/bin目錄啟動hbase:./start-hbase.sh
- 用
jps
命令檢視Hbase是否啟動成功,如果啟動成功的會看到”HMaster”的程式 - 初始化pinpoint需要的表:./hbase shell hbase-create.hbase (這裡的hbase-create.hbase在原始碼
pinpoint/hbase/scripts/hbase-create.hbase
) - 訪問頁面測試是否成功:http://localhost:16010/master-status ,如果成功在頁面的tables標籤下能看到匯入的表。
- 也可以用命令來檢視是否匯入表成功,進入hbase,輸入”status ‘detailed'”可以檢視初始化的表
./hbase shell status 'detailed'
2. 部署Pinpoint-collector
- 將pinpoint-collector-1.6.0-SNAPSHOT.war放到tomcat-collector-8086/webapps/下,並重新命名為ROOT.war
- 啟動tomcat,配置ROOT/WEB-INF/classes/hbase.properties:
hbase.client.host=localhost hbase.client.port=2181
指向zookeeper的地址和埠,如果是本機,埠預設,則這裡不需更改。
- 配置上面後,重啟tomcat(埠8086)
3. 部署Pinpoint-web
Pinpoint-web的配置和Pinpoint-collector相似:
- 將pinpoint-web-1.6.0-SNAPSHOT.war放到tomcat-web-8085/webapps/下,並重新命名為ROOT.war
- 啟動tomcat,配置ROOT/WEB-INF/classes/hbase.properties:
hbase.client.host=localhost hbase.client.port=2181
指向zookeeper的地址和埠,如果是本機,埠預設,則這裡不需更改。
- 配置上面後,重啟tomcat(埠8085)
4. 部署Pinpoint-agent
- 新建目錄:mkdir pp-agent
- 將pinpoint-agent-1.6.0-SNAPSHOT.tar.gz 拷貝到pp-agent目錄並解壓
- 配置pinpoint.config:profiler.collector.ip=127.0.0.1這是指pinpoint-collector的地址,如果是同一伺服器,則不用修改。其它預設。
- 安裝pinpoint-collector啟動後,自動就開啟了9994,9995,9996的埠了,這裡預設即可。如果有埠需求,要去pinpoint-collector的配置檔案(“pinpoint-collector/webapps/ROOT/WEB-INF/classes/pinpoint-collector.properties”)中,修改這些埠。
5. 部署TestApp
- 官方提供了一個測試用的應用,pinpoint-quickstart-testapp-null.war,將其重新命名為ROOT.war,部署到tomcat-testapp-8084
- 修改此tomat的
/bin/catalina.sh
,在106行左右加入啟動引數:
CATALINA_OPTS="$CATALINA_OPTS -javaagent:/Users/acheron/pinpoint/pp-agent/pinpoint-bootstrap-1.6.0.jar" CATALINA_OPTS="$CATALINA_OPTS -Dpinpoint.agentId=myapp" CATALINA_OPTS="$CATALINA_OPTS -Dpinpoint.applicationName=MyTestPP"
第一行:pinpoint-bootstrap-1.6.0.jar的位置
第二行:這裡的agentId必須唯一,標誌一個jvm。
第三行:applicationName表示同一種應用:同一個應用的不同例項應該使用不同的agentId,相同的applicationName。
6. springboot包部署
如果是jar包部署,直接在啟動命令加啟動引數:
nohup java -javaagent:/Users/acheron/pinpoint/pp-agent/pinpoint-bootstrap-1.6.0.jar -Dpinpoint.agentId=acheron-consumer -Dpinpoint.applicationName=acheron-consumer -jar myapp.jar &
7.效果演示
hbase和各應用都啟動成功之後,訪問Pinpoint-web,效果:
結束語
各大APM工具,幾乎都是根據google這篇經典的Dapper論文而來,一定要讀一讀。這裡是它的源文地址:https://research.google.com/pubs/pub36356.html,感謝這位同學的翻譯:http://bigbully.github.io/Dapper-translation/
參考文章
相關文章
- Dubbo 整合 Pinpoint 做分散式服務請求跟蹤分散式
- Centos下分散式跟蹤工具Pinpoint的完整部署記錄CentOS分散式
- 分散式訊息中介軟體分散式
- DiagnosticSource DiagnosticListener 無侵入式分散式跟蹤分散式
- Welcome to YARP - 8.分散式跟蹤分散式
- 像跟蹤分散式服務呼叫那樣跟蹤 Go 函式呼叫鏈分散式Go函式
- go-micro整合鏈路跟蹤的方法和中介軟體原理Go
- 分散式跟蹤系統zipkin簡介分散式
- 分散式系統的跟蹤系統分散式
- Dapper分散式跟蹤系統論文APP分散式
- LAF-DTX分散式事務中介軟體分散式
- 中介軟體---分散式任務排程---Celery分散式
- 分散式跟蹤系統——產品對比分散式
- 微服務分散式跟蹤工具Brave簡介微服務分散式
- 深入理解阿里分散式訊息中介軟體阿里分散式
- 分散式資料庫中介軟體 MyCat 搞起來!分散式資料庫
- 分散式呼叫鏈跟蹤工具Jaeger?兩分鐘極速體驗分散式
- 使用zipKin構建NetCore分散式鏈路跟蹤NetCore分散式
- 分散式事務中介軟體Seata的設計原理分散式
- 使用Spring Cloud Sleuth和OpenTelemetry實現分散式跟蹤SpringCloud分散式
- MyCat的坑如何在分散式中介軟體DBLE上改善分散式
- 滴滴開源分散式訊息中介軟體產品DDMQ分散式MQ
- 搭建JEESZ分散式架構--訊息中介軟體簡介分散式架構
- 《中介軟體效能挑戰賽--分散式統計和過濾的鏈路追蹤》java 選手分享分散式Java
- Timemator自動化時間跟蹤軟體
- 【中介軟體】Redis 實戰之主從複製、高可用、分散式Redis分散式
- CECTC/dbpack: 用Golang編寫的分散式事務中介軟體Golang分散式
- [分散式][訊息中介軟體]訊息中介軟體如何實現每秒幾十萬的高併發寫入分散式
- 原理 | 分散式鏈路跟蹤元件 SOFATracer 和 Zipkin 模型轉換分散式元件模型
- Spring Cloud Sleuth 和 Zipkin 進行分散式跟蹤使用指南SpringCloud分散式
- Timemator for Mac(自動化時間跟蹤軟體)Mac
- 分散式事務中介軟體 Fescar—RM 模組原始碼解讀分散式原始碼
- 分散式系統訊息中介軟體——RabbitMQ的使用進階篇分散式MQ
- 第九章 webase 分散式中介軟體平臺快速部署Web分散式
- 分散式資料庫中介軟體 MyCat | 分庫分表實踐分散式資料庫
- 從訊息中介軟體看分散式系統的多種套路分散式
- 叢集及分散式定時任務中介軟體MEE_TIMED分散式
- SpringBoot分散式任務中介軟體開發 附視訊講解 (手把手教你開發和使用中介軟體)Spring Boot分散式