Skywalking系列博客2-Skywalking使用

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 ) ,不過這兩種使用方式目前還不是特別流行,故此不作贅述,其實也比較簡單。感興趣的童鞋也能夠研究一下。

配置java agent

  • 找到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 修改爲你的微服務名稱;
    • 若是Skywalking和微服務部署在不一樣的服務器,還需修改 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中啓動測試,則可參考下圖配置,而後啓動便可。

    img

傳統Tomcat應用

Linux Tomcat 7-9

修改 tomcat/bin/catalina.sh 的第一行:

CATALINA_OPTS="$CATALINA_OPTS -javaagent:/opt/agent/skywalking-agent.jar"; export CATALINA_OPTS

Windows Tomcat 7-9

修改 tomcat/bin/catalina.bat 的第一行:

set "CATALINA_OPTS=-javaagent:/opt/agent/skywalking-agent.jar"

效果演示

使用Skywalking監控應用後,當應用API被訪問時,就會展現相似以下的圖表。

首頁:

image-20191219003122935

網絡拓撲:能夠分析請求的網絡去向。例以下圖,表示請求首先打到了foodie-dev這個微服務,而後又請求了localhost:3306 這個MySQL數據庫。

image-20191219003107863

追蹤:這個導航欄是咱們定位問題時最經常使用的,能夠搜索查詢的具體細節。定位性能瓶頸出在了哪一個階段。

image-20191219003143025

告警:顧名思義。Skywalking可配置告警規則,當超出配置的閾值時,就推送告警信息。

指標對比:能夠對任意的指標進行對比。

相關文章

原文首發

http://www.itmuch.com/skywalking/skywalking-using/

本文由博客一文多發平臺 OpenWrite 發佈!