线程异常关注两个东西,一个是线程状态,一个是线程的连接数
应用设计的时候需要考虑资源的限制,才能避免应用在某些时候因为资源过度而崩溃,线程数的控制非常重要。程序无限制的创建最终导致不可控,特别是隐藏在代码中的创建线程的方法
当系统的SY值过高时,表示linux要花费更多的时间来进行线程的切换。java造成这样现象的主要原因是创建的线程比较多,这些线程都处于不断的阻塞、锁等待、IO等待和执行状态的变化过程中,这就产生了大量的上下文切换。java程序在创建线程时会操作JVM堆外的物理内存,太多的线程也会使用过多的物理内存,导致了系统报如下错误
Exception in thread "main" java.lang.OutOfMemoryError:
unable to creat new native thread
这个错误即系统创建了太多的线程导致
线程数
以下几种命令都可以帮忙定位线程数的问题
- cat /proc/pid/status
- top -bH -d 3 -p pid
- pstree -p pid | wc -l pstack
- pid | head -1
cat /proc/pid/status
线程状态
线程状态有:
- blocked(当一个线程试图获取一个对象锁,而这对象锁被其他线程持有)
- Waiting(一个线程在等待另一个线程执行唤醒动作)
- Time_Waiting(线程在遇到sleep方法和wait方法时就会进入Time Waiting状态)
- New Runnable(线程刚被创建,但未被启动)
- Terminated(因为run方法正常的退出而死亡,或者因为遇到异常而死亡)
其中最需要关注的是 blocked、Waiting和Time_Waiting的状态。特别是block状态,在获取不到CPU执行时间的时候,这样系统的性能就会下降
CPU飙升需要定位程序CPU的问题以及查看线程状态的问题