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

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sysu_lluozh

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值