TIPSjava
本文基於Skywalking 6.6.0編寫,理論支持Skywalking 6.0+全部版本。git
本文探討如何使用Skywalking監控應用。github
Skywalking有多種使用方式,目前最流行(也是最強大)的使用方式是基於Java agent的。spring
Java agent支持的框架、中間件等,可在 https://github.com/apache/skywalking/blob/v6.6.0/docs/en/setup/service-agent/java-agent/Supported-list.md
查看。數據庫
TIPSapache
- 除Java agent方式外,Skywalking還支持其餘語言的agent,詳見
https://github.com/apache/skywalking/blob/v6.6.0/docs/en/setup/README.md#language-agents-in-service
- 此外,Skywalking還支持基於Service Mesh(例如Istio,詳見
https://github.com/apache/skywalking/blob/v6.6.0/docs/en/setup/README.md#service-mesh
)、Proxy(例如Envoy Proxy,詳見https://github.com/apache/skywalking/blob/v6.6.0/docs/en/setup/README.md#service-mesh
) ,不過這兩種使用方式目前還不是特別流行,故此不作贅述,其實也比較簡單。感興趣的童鞋也能夠研究一下。
找到SkyWalking包中的 agent
目錄,agent目錄結構以下tomcat
+-- agent +-- activations apm-toolkit-log4j-1.x-activation.jar apm-toolkit-log4j-2.x-activation.jar apm-toolkit-logback-1.x-activation.jar ... +-- config agent.config +-- plugins apm-dubbo-plugin.jar apm-feign-default-http-9.x.jar apm-httpClient-4.x-plugin.jar ..... skywalking-agent.jar
將 agent
目錄拷貝到任意位置服務器
配置網絡
config/agent.config
:框架
agent.service_name
修改爲你的微服務名稱;collector.backend_service
的值,該配置用來指定微服務和Skywalking通訊的地址,默認是 127.0.0.1:11800
,按需修改便可。固然 agent.config
文件裏面有不少的配置,本文下面的表格有詳細講解。java -jar
啓動的應用例如,有一個Spring Boot應用,則修改完 agent
目錄後:
執行以下命令啓動:
# 注意-javaagent得在-jar以前哦 java -javaagent:/opt/agent/skywalking-agent.jar -jar somr-spring-boot.jar
若是想在IDE中啓動測試,則可參考下圖配置,而後啓動便可。
修改 tomcat/bin/catalina.sh
的第一行:
CATALINA_OPTS="$CATALINA_OPTS -javaagent:/opt/agent/skywalking-agent.jar"; export CATALINA_OPTS
修改 tomcat/bin/catalina.bat
的第一行:
set "CATALINA_OPTS=-javaagent:/opt/agent/skywalking-agent.jar"
使用Skywalking監控應用後,當應用API被訪問時,就會展現相似以下的圖表。
首頁:
網絡拓撲:能夠分析請求的網絡去向。例以下圖,表示請求首先打到了foodie-dev這個微服務,而後又請求了localhost:3306
這個MySQL數據庫。
追蹤:這個導航欄是咱們定位問題時最經常使用的,能夠搜索查詢的具體細節。定位性能瓶頸出在了哪一個階段。
告警:顧名思義。Skywalking可配置告警規則,當超出配置的閾值時,就推送告警信息。
指標對比:能夠對任意的指標進行對比。
http://www.itmuch.com/skywalking/skywalking-using/
本文由博客一文多發平臺 OpenWrite 發佈!