线程状态死锁, DeadLock, 多个线程调用间, 进入相互资源占用, 导致一直等待无法释放的情况;
执行中, Runnable, 指该线程正在执行状态中, 该线程占用了资源, 正在处理某个请求, 或者正在传递 SQL 到数据库执行, 或对某个文件操作, 或进行数据类型转换等;
等待资源, Waiting on condition, 等待资源, 或等待某个条件的发生;(结合 stacktrace 分析)情况一, 是网络忙, 消耗了所有的带宽, 仍然有大量数据等待网络的读写;
情况二, 网络空闲, 但由于路由等问题, 导致包丢失无法正常到达;如果栈信息明确是应用代码, 则证明该线程正在等待资源, 一般是大量读取某资源, 且该资源采用了资源锁的情况下, 线程进入了等待状态, 等待资源的读取;
或者正在等待其他线程的执行;
如果发现大量的线程处于 Waiting on condition, 从线程 stack 上看, 正等待网络的读写, 这可能是网络瓶颈的征兆, 因为网络阻塞导致的线程无法执行;
大部分这种状态是因为线程处于 sleep, 等待 sleep 的时间到了时候被唤醒;
等待获取监视器, Waiting on monitor entry
暂停, Suspended
对象等待中, Object.wait() or TIMED_WAITING
阻塞, Blocked, 线程阻塞, 指当前线程执行过程中, 所需要的资源长时间等待却一直未能获取到, 被容器的线程管理器标识为阻塞状态, 可理解为等待资源超时的线程;
停止, Parked
Monitor 是 Java 中用以实现线程之间的互斥与协作的主要手段, 可以看成是对象或者 Class 的锁; 每个对象都有, 也仅有一个 monitor;