16.2.3 查看应用程序活动
关注应用程序中的活动是非常有用的。这些活动包括应用程序正在处理的各种 HTTP 请求,以及应用程序中的所有线程等等。为此,Actuator 提供了 /httptrace
、/threaddump
和 /heapdump
端点。
/heapdump
端点可能是 Actuator 最难详细描述的端点。简单来说,它下载一个 gzip 压缩的 HPROF
堆转储文件,以便对内存或线程问题进行分析跟踪。因篇幅原因,且堆转储的使用是一个相当高级的特性,所以仅在这里提一下 /heapdump
端点。
跟踪 HTTP 活动
/httptrace
端点报告应用处理的最近 100 个请求。详细信息包括请求的方法和路径、时间戳、请求和响应的头信息,以及处理请求的耗时。
下面的 JSON 片段显示了 /httptrace
端点的返回:
这些信息可能对调试很有用,但更有趣的是,随着时间的推移跟踪这些数据,可以深入了解应用程序运行状况。可以了解在给定的时间段内,应用的繁忙程度,或根据响应状态的值,统计有多少成功的请求和失败的请求。在第 17 章中,您将看到 Spring Boot Admin 如何捕获这些信息,并且将这些 HTTP 跟踪信息可视化到一个运行图中。
监视线程
除了对 HTTP 请求进行跟踪之外,要确定应用程序的运行情况,监视线程活动状态也非常有用的。/threaddump
端点生成一个当前线程活动的快照。下面是 /threaddump
响应数据片段,可以了解此端点都提供了哪些信息:
完整的线程转储报告,包括正在运行的应用程序中的每个线程。为了节省篇幅,这里的线程转储信息只显示了单个线程的一个简化条目。您可以看到,它包括线程有关的阻塞和锁定状态的详细信息,以及其他一些细节。还有一个堆栈跟踪,可以提供一些线程在代码的哪个区域所花费时间的信息。
因为 /threaddump
端点只会把请求时的线程快照信息取出来,很难全面了解线程的行为是如何随着时间的推移变化的。在第 17 章中,您将看到 Spring Boot Admin 如何实时监视 /threaddump
端点。
最后更新于