Java 线程:解释正在运行的 JVM 的线程状态

kno*_*orv 5 java performance multithreading stack-trace jstack

Java 线程始终处于以下十种状态之一:

NEW: Just starting up, i.e., in process of being initialized.
NEW_TRANS: Corresponding transition state (not used, included for completness).
IN_NATIVE: Running in native code.
IN_NATIVE_TRANS: Corresponding transition state.
IN_VM: Running in VM.
IN_VM_TRANS: Corresponding transition state.
IN_JAVA: Running in Java or in stub code.
IN_JAVA_TRANS: Corresponding transition state (not used, included for completness).
BLOCKED: Blocked in vm.
BLOCKED_TRANS: Corresponding transition state.
Run Code Online (Sandbox Code Playgroud)

未使用的状态 ( UNINITIALIZED) 已从列表中省略。

虽然上面给出了状态的定义,但我正在寻找“经验法则”来解释正在运行的应用程序服务器的给定线程状态设置。并且,更具体地说:

假设一个实时应用程序服务器在不同时间点具有以下线程统计信息(使用jstack获得):

  • 100 个线程: 35 BLOCKED、 65IN_NATIVE
  • 113 个线程: 35 BLOCKED、 77 IN_NATIVE、 1IN_VM
  • 52 个线程: 38 BLOCKED、 1 IN_JAVA、 6 IN_NATIVE、 7IN_VM
  • 120 个线程: 39 BLOCKED、 1 IN_JAVA、 80IN_NATIVE
  • 94 个线程: 34 BLOCKED、 59 IN_NATIVE、 1IN_NATIVE_TRANS

对于五个统计数据中的每个线程 - 可以推断出有关 JVM 整体状态的什么信息?即“在这种情况下,JVM 看起来正在空闲等待请求”、“机器正忙于处理请求”等。

kdg*_*ory 4

此级别的输出无法提供足够的信息来做出此类陈述。

举个例子,考虑 BLOCKED 状态:有很多事情可能导致线程被阻塞。其中两个正在等待来自客户端的数据,并等待数据从数据库返回。在第一种情况下,您的应用程序处于空闲状态,在第二种情况下,您的应用程序已过载。

编辑:没有查看 jstack 的输出,我想这两个条件也可以表示为 IN_NATIVE。然而,同样的评论也成立:您不知道他们在做什么,因此您无法对整个应用程序做出任何陈述。