1. APM簡述php
APM (Application Performance Management)是對企業的應用系統進行實時監控,它是用於實現對應用程序性能管理和故障管理的系統化的解決方案。html
2.APM主要解決的問題:java
......node
3.分佈式調用追蹤(APM)一覽mysql
4.方案對比c++
pinpointgit |
zipkingithub |
jaegerspring |
skywalkingsql |
|
OpenTracing兼容 |
否 |
是 |
是 |
是 |
客戶端支持語言 |
java、php |
java,c#,go,php等 |
java,c#,go,php等 |
Java, .NET Core, NodeJS and PHP |
存儲 |
hbase |
ES,mysql,Cassandra,內存 |
ES,kafka,Cassandra,內存 |
ES,H2,mysql,TIDB,sharding sphere |
傳輸協議支持 |
thrift |
http,MQ |
udp/http |
gRPC |
ui豐富程度 |
高 |
低 |
中 |
中 |
實現方式-代碼侵入性 |
字節碼注入,無侵入 |
攔截請求,侵入 |
攔截請求,侵入 |
字節碼注入,無侵入 |
擴展性 |
低 |
高 |
高 |
中 |
trace查詢 |
不支持 |
支持 |
支持 |
支持 |
告警支持 |
支持 |
不支持 |
不支持 |
支持 |
jvm監控 |
支持 |
不支持 |
不支持 |
支持 |
性能損失 |
高 |
中 |
中 |
低 |
5.各方案參考連接
1.pinpoint-naver
github: https://github.com/naver/pinpoint
docker快速體驗:https://github.com/naver/pinpoint-docker
2.zipkin-推特:
github: https://github.com/openzipkin/zipkin
頁面詳解:https://blog.csdn.net/u012394095/article/details/82585863
zipkin於php對接:https://www.colabug.com/1872361.html
3.jaeger-uber
部分參考資料:
jaeger簡介,部署,入門實踐 http://www.javashuo.com/article/p-vsitlayu-kz.html
jaeger——java實現 http://www.javashuo.com/article/p-akkfjcqa-go.html
Uber分佈式追蹤系統Jaeger使用介紹和案例(PHP Hprose Go 跨語言調用)
https://segmentfault.com/a/1190000011636957
全鏈路監控Jaeger搭建實戰 https://www.jianshu.com/p/ffc597bb4ce8
jaeger官網快速開始 https://www.jaegertracing.io/docs/1.8/getting-started/
4.skywalking(推薦)
github: https://github.com/apache/incubator-skywalking
SkyWalking 分佈式追蹤系統 https://www.jianshu.com/p/2fd56627a3cf
Apache SkyWalking 5.0中文版圖文詳解使用手冊
http://skywalking.apache.org/zh/blog/2018-12-18-Apache-SkyWalking-5-0-UserGuide.html
skywalking學習筆記 http://www.javashuo.com/article/p-kfqwvqqh-dp.html
6.參考資料
分佈式鏈路追蹤技術對比 http://www.javashuo.com/article/p-uiycrkus-ey.html
回到網易後開源 APM 技術選型與實戰 https://www.infoq.cn/article/apm-Pinpoint-practice
zipkin vs jaeger http://www.javashuo.com/article/p-ywqoanff-br.html
調用鏈選型之Zipkin,Pinpoint,SkyWalking,CAT https://www.jianshu.com/p/0fbbf99a236e