【性能调优】线程异常问题

线程异常关注两个东西,一个是线程状态,一个是线程的连接数
应用设计的时候需要考虑资源的限制,才能避免应用在某些时候因为资源过度而崩溃,线程数的控制非常重要。程序无限制的创建最终导致不可控,特别是隐藏在代码中的创建线程的方法
当系统的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的问题以及查看线程状态的问题

posted @ 2020-03-19 02:06  guanqinghua  阅读(61)  评论(0编辑  收藏  举报