zoukankan      html  css  js  c++  java
  • 【性能调优】线程异常问题

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

  • 相关阅读:
    SP6779 GSS7
    P2218 [HAOI2007]覆盖问题
    day10-包的定义和内部类
    day09-final、多态、抽象类、接口
    day08-代码块和继承
    day07-变量,封装
    day05-方法、数组
    day04-switch、循环语句
    day03-运算符、键盘录入
    day02-基本概念
  • 原文地址:https://www.cnblogs.com/guanhuohuo/p/12533554.html
Copyright © 2011-2022 走看看