首页
学习
活动
专区
工具
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

    4.1K30

    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.8K21

    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

    Tomcat占用CPU过高解决方法

    问题描述 在工作中经常遇到Tomcat占用CPU居高不下,top显示结果超过200%,请求无法响应,针对这种情况有以下处理办法进行排查。请求无法响应。...命令可以快速查出jvm进程 jps pid 2、查看jstack信息 jstack pid 3、将十进制pid转换为16进制 将十进制转换成16进制 # printf "%x\n" 19713-->将第2步查到占用较高...CPU的线程号转换为16进制,以便于jstack查看 4d01 #jstack pid | grep 0x4d01--> 0x4d01为第3步19713转换为16进制后的数字,因为jstack显示的线程号是以...占用量 简单点儿的方法则是,查出进程id后,通过如下命令查看该进程中每个线程的资源使用情况 top -H -p pid  -H用于显示某个进程的所有线程 从这里获取pid(线程id),转换为16进制,然后去...通过上述方法,查出tomcat进程对应的线程cpu占用率累积之和约80%,远小于top给出的200%+ 说明并不存在长期占用cpu的线程,应该是属于有许多短暂性的cpu密集计算。

    3.1K10
    领券