首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    CPU占用过高排查

    一.简介 最近一段时间 某台服务器上的一个应用总是隔一段时间就自己挂掉 用top看了看 从重新部署应用开始没有多长时间CPU占用上升得很快 排查步骤 1.使用top 定位到占用CPU高的进程PID top...2.通过ps aux | grep PID命令 获取线程信息,并找到占用CPU高的线程 ps -mp pid -o THREAD,tid,time | sort -rn 3.将需要的线程ID转换为16...printf "%x\n" tid 4.打印线程的堆栈信息 到了这一步具体看堆栈的日志来定位问题了 jstack pid |grep tid -A 30 二.例子 1.top 可以看出PID 733进程 的占用...CPU 172% 2.查找进程733下的线程 可以看到TID 线程775占用了96%且持有了很长时间 其实到这一步基本上能猜测到应该是 肯定是那段代码发生了死循环 ps -mp 733 -o THREAD

    3.9K30

    cpu占用过高排查

    简介 最近一段时间 某台服务器上的一个应用总是隔一段时间就自己挂掉 用top看了看 从重新部署应用开始没有多长时间CPU占用上升得很快 排查步骤 # 1.使用top 定位到占用CPU高的进程PID...top # 2.通过ps aux | grep PID命令 获取线程信息,并找到占用CPU高的线程 ps -mp pid -o THREAD,tid,time | sort -rn # 3.将需要的线程...printf "%x\n" tid # 4.打印线程的堆栈信息 到了这一步具体看堆栈的日志来定位问题了 jstack pid |grep tid -A 30 案例 1.top可以看到PID733进程的占用...显然是 SmsQueueServiceImpl 中的produceMissSms 和 consumeMissSms 方法有问题 最后注释掉那段循环代码,cpu占用就正常了,也有可能是因为频繁GC导致CPU...占用过高

    2.4K51

    CPU占用100%排查过程

    article/details/80791704 https://www.javatang.com/archives/2017/10/19/51301886.html 机器是2C 4G,程序启动之后, CPU...使用率就直接100%了,碰到这种问题完全没有头绪,没这方面的经验,只能硬着头皮一点点查资料 排查过程 1、top 通过top命令找到,找到最耗CPU的进行PID,从下图种可以发现PID为 15913...2、top -p 15913 -H 加上 -H 选项可以该进程的相关线程信息,从下图种可知最耗CPU的两个线程PID分别是 15924和15925,对应的16进制为 0x3e34和0x3e35 ?...在日志的最后面找到了0x3e34和0x3e35,对应的是GC线程,由此猜想可能是不停的GC导致CPU占用过高。...7、增大堆内存 -Xms2048m -Xmx2048m,增大堆内存到2048MB,重启查看效果 【系统启动的之后的3s内,CPU占用还是100%,接下来就降下来了。

    4.7K21

    liteos CPU占用率(十六)

    概述 1.1 基本概念 CPU(中央处理器, Central Processing Unit)占用率可以分为系统CPU占用率和任务CPU占用率两种。...系统CPU占用率(CPU Percent)是指周期时间内系统的CPU占用率,用于表示系统一段时间内的闲忙程度,也表示CPU的负载情况。...系统CPU占用率的有效表示范围为0~100,其精度(可通过配置调整)为百分比。 100表示系统满负荷运转。 任务CPU占用率指单个任务的CPU占用率,用于表示单个任务在一段时间内的闲忙程度。...Huawei LiteOS提供以下两种CPU占用率的信息查询: 系统CPU占用率。 任务CPU占用率。...功能分类 接口名 描述 获取系统CPU占用率 LOS_SysCpuUsage 获取当前系统CPU占用率 --- LOS_HistorySysCpuUsage 获取系统历史CPU占用率 获取任务CPU占用

    1.7K20

    面试杂谈 - CPU占用高如何排查

    程序里少不了运算,如果不是环境太恶劣,CPU基本是能支撑应用运行的。但如果发现CPU居高不下,就需要思考是否程序有问题。 当服务器CPU居高不下,可以从下面几个方面入手定位问题。...00:05:11 java -jar acupjava-1.0-SNAPSHOT.jar 找到进程中CPU高的线程 tid 打印出线程线程基本信息,找到cpu百分比高的一个或几个线程,记住它们的tid。...PS:栗子质量不好,全是0.0%,不要在意~ [root@iZba13i1mo82ot7a3lhq5oZ ~]# ps -mp 26016 -o THREAD,tid,time USER %CPU...iZba13i1mo82ot7a3lhq5oZ ~]# jstack 26016 >> stack.txt [root@iZba13i1mo82ot7a3lhq5oZ ~]# ls test stack.txt 找到占用...CPU高的线程 打开文件,搜索tid所在位置,可以看到线程栈,由此分析定位可能有问题的代码。

    1.6K31
    领券