16.2.3 查看应用程序活动

关注应用程序中的活动是非常有用的。这些活动包括应用程序正在处理的各种 HTTP 请求,以及应用程序中的所有线程等等。为此,Actuator 提供了 /httptrace/threaddump/heapdump 端点。

/heapdump 端点可能是 Actuator 最难详细描述的端点。简单来说,它下载一个 gzip 压缩的 HPROF 堆转储文件,以便对内存或线程问题进行分析跟踪。因篇幅原因,且堆转储的使用是一个相当高级的特性,所以仅在这里提一下 /heapdump 端点。

跟踪 HTTP 活动

/httptrace 端点报告应用处理的最近 100 个请求。详细信息包括请求的方法和路径、时间戳、请求和响应的头信息,以及处理请求的耗时。

下面的 JSON 片段显示了 /httptrace 端点的返回:

{
  "traces": [
    {
      "timestamp": "2018-06-03T23:41:24.494Z",
      "principal": null,
      "session": null,
      "request": {
        "method": "GET",
        "uri": "http://localhost:8081/ingredients",
        "headers": {
          "Host": ["localhost:8081"],
          "User-Agent": ["curl/7.54.0"],
          "Accept": ["*/*"]
        },
        "remoteAddress": null
      },
      "response": {
        "status": 200,
        "headers": {
          "Content-Type": ["application/json;charset=UTF-8"]
        }
      },
      "timeTaken": 4
    },
  ...
  ]
}

这些信息可能对调试很有用,但更有趣的是,随着时间的推移跟踪这些数据,可以深入了解应用程序运行状况。可以了解在给定的时间段内,应用的繁忙程度,或根据响应状态的值,统计有多少成功的请求和失败的请求。在第 17 章中,您将看到 Spring Boot Admin 如何捕获这些信息,并且将这些 HTTP 跟踪信息可视化到一个运行图中。

监视线程

除了对 HTTP 请求进行跟踪之外,要确定应用程序的运行情况,监视线程活动状态也非常有用的。/threaddump 端点生成一个当前线程活动的快照。下面是 /threaddump 响应数据片段,可以了解此端点都提供了哪些信息:

完整的线程转储报告,包括正在运行的应用程序中的每个线程。为了节省篇幅,这里的线程转储信息只显示了单个线程的一个简化条目。您可以看到,它包括线程有关的阻塞和锁定状态的详细信息,以及其他一些细节。还有一个堆栈跟踪,可以提供一些线程在代码的哪个区域所花费时间的信息。

因为 /threaddump 端点只会把请求时的线程快照信息取出来,很难全面了解线程的行为是如何随着时间的推移变化的。在第 17 章中,您将看到 Spring Boot Admin 如何实时监视 /threaddump 端点。

最后更新于

这有帮助吗?