jstack应用-查找CPU飚高的原因

场景

在系统上线后,经常会遇到运维的同学跑过来说:“这次发版后,cpu线程使用率到一场,到100%了”。这时候不要慌,可以使用堆转储来分析到底是哪个线程引起的。

查找元凶

[root@java_mofei_01 test]# top
Mem:  16333644k total,  9472968k used,  6860676k free,   165616k buffers
Swap:        0k total,        0k used,        0k free,  6665292k cachedPID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                                                                                                                                           
17850 root      20   0 7588m 112m  11m S 100.7  0.7  47:53.80 java                                                                                                                                                                                              1552 root      20   0  121m  13m 8524 S  0.7  0.1  14:37.75 AliYunDun                                                                                                                                                                                          3581 root      20   0 9750m 2.0g  13m S  0.7 12.9 298:30.20 java                                                                                                                                                                                               1 root      20   0 19360 1612 1308 S  0.0  0.0   0:00.81 init                                                                                                                                                                                               2 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kthreadd                                                                                                                                                                                           3 root      RT   0     0    0    0 S  0.0  0.0   0:00.14 migration/0   

发现pid=17850的进程线程使用率100%,查询进程中哪个线程导致的问题

[root@java_mofei_01 test]# top -H -p 17850
top - 17:43:15 up 5 days,  7:31,  1 user,  load average: 0.99, 0.97, 0.91
Tasks:  32 total,   1 running,  31 sleeping,   0 stopped,   0 zombie
Cpu(s):  3.7%us,  8.9%sy,  0.0%ni, 87.4%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:  16333644k total,  9592504k used,  6741140k free,   165700k buffers
Swap:        0k total,        0k used,        0k free,  6781620k cachedPID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                                                                                                                                           
17880 root      20   0 7588m 112m  11m R 99.9  0.7  50:47.43 java                                                                                                                                                                                               
17856 root      20   0 7588m 112m  11m S  0.3  0.7   0:02.08 java                                                                                                                                                                                               
17850 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17851 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.23 java                                                                                                                                                                                               
17852 root      20   0 7588m 112m  11m S  0.0  0.7   0:02.09 java                                                                                                                                                                                               
17853 root      20   0 7588m 112m  11m S  0.0  0.7   0:02.12 java                                                                                                                                                                                               
17854 root      20   0 7588m 112m  11m S  0.0  0.7   0:02.07 java                                                                                                                                                                                               
17855 root      20   0 7588m 112m  11m S  0.0  0.7   0:02.06 java                                                                                                                                                                                               
17857 root      20   0 7588m 112m  11m S  0.0  0.7   0:02.07 java                                                                                                                                                                                               
17858 root      20   0 7588m 112m  11m S  0.0  0.7   0:02.08 java                                                                                                                                                                                               
17859 root      20   0 7588m 112m  11m S  0.0  0.7   0:02.04 java                                                                                                                                                                                               
17860 root      20   0 7588m 112m  11m S  0.0  0.7   0:02.05 java                                                                                                                                                                                               
17861 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17862 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17863 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17864 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.10 java                                                                                                                                                                                               
17865 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.12 java                                                                                                                                                                                               
17866 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.09 java                                                                                                                                                                                               
17867 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.12 java                                                                                                                                                                                               
17868 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17869 root      20   0 7588m 112m  11m S  0.0  0.7   0:01.04 java                                                                                                                                                                                               
17870 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17871 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17872 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17873 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17874 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17875 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17876 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17877 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17878 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17879 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java                                                                                                                                                                                               
17946 root      20   0 7588m 112m  11m S  0.0  0.7   0:00.00 java    

发现17880的线程导致cpu飚高。

通过jstack查看线程信息

[root@java_mofei_01 test]# printf "%x\n" 17880          
45d8
[root@java_mofei_01 test]# jstack 17850|grep 45d8 -A 30
"pool-1-thread-11" #20 prio=5 os_prio=0 tid=0x00007fc860352800 nid=0x45d8 runnable [0x00007fc8417d2000]java.lang.Thread.State: RUNNABLEat java.io.FileOutputStream.writeBytes(Native Method)at java.io.FileOutputStream.write(FileOutputStream.java:326)at java.io.BufferedOutputStream.flushBuffer(BufferedOutputStream.java:82)at java.io.BufferedOutputStream.flush(BufferedOutputStream.java:140)- locked <0x00000006c6c2e708> (a java.io.BufferedOutputStream)at java.io.PrintStream.write(PrintStream.java:482)- locked <0x00000006c6c10178> (a java.io.PrintStream)at sun.nio.cs.StreamEncoder.writeBytes(StreamEncoder.java:221)at sun.nio.cs.StreamEncoder.implFlushBuffer(StreamEncoder.java:291)at sun.nio.cs.StreamEncoder.flushBuffer(StreamEncoder.java:104)- locked <0x00000006c6c26620> (a java.io.OutputStreamWriter)at java.io.OutputStreamWriter.flushBuffer(OutputStreamWriter.java:185)at java.io.PrintStream.write(PrintStream.java:527)- eliminated <0x00000006c6c10178> (a java.io.PrintStream)at java.io.PrintStream.print(PrintStream.java:597)at java.io.PrintStream.println(PrintStream.java:736)- locked <0x00000006c6c10178> (a java.io.PrintStream)at com.demo.guava.HardTask.call(HardTask.java:18)at com.demo.guava.HardTask.call(HardTask.java:9)at java.util.concurrent.FutureTask.run(FutureTask.java:266)at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)at java.lang.Thread.run(Thread.java:745)"pool-1-thread-10" #19 prio=5 os_prio=0 tid=0x00007fc860345000 nid=0x45d7 waiting on condition [0x00007fc8418d3000]java.lang.Thread.State: WAITING (parking)at sun.misc.Unsafe.park(Native Method)- parking to wait for  <0x00000006c6c14178> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)at java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)
  • 首先把pid 17880转成16进制
  • 查询堆信息
  • 发现HardTask(源码在末尾)第18行可能有问题

    源码

public class HardTask implements Callable<String> {@Overridepublic String call() throws Exception {while(true){int a=100;int b=100;int rs=a+b/100-b;System.out.println(rs);}}
}public class SimpleTask implements Callable<String> {@Overridepublic String call() throws Exception {Thread.sleep(300);//什么都不做return null;}
}public class CpuTest {public static void main(String[] args){ExecutorService executorService=Executors.newFixedThreadPool(11);for (int i = 0; i < 10; i++) {executorService.submit(new SimpleTask());}executorService.submit(new HardTask());}
}

源码很简单,就是创建了2种线程HardTask和SimpleTask。然后通过CpuTest进行启动。

转载于:https://blog.51cto.com/4436396/2118787

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/254544.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Enhancement增强图形halcon算子,持续更新

目录coherence_enhancing_diffemphasizeequ_histo_imageilluminatemean_curvature_flowscale_image_max_shock_filtercoherence_enhancing_diff 功能&#xff1a;执行一个图像的一个一致性增强扩散。 emphasize 功能&#xff1a;增强图像对比度。 equ_histo_image 功能&am…

音频中采样位数,采样率,比特率的名词解释(转)

采样位数&#xff08;采样大小&#xff09;&#xff1a; 采样位数可以理解为采集卡处理声音的解析度。这个数值越大&#xff0c;解析度就越高&#xff0c;录制和回放的声音就越真实。我们首先要知道&#xff1a;电脑中的声音文件是用数字0和1来表示的。所以在电脑上录音的本质就…

WebSocket实时异步通信

WebSocket实时异步通信 【一】WebSocket简介 WebSocket是HTML5推出一个协议规范&#xff0c;用来B/S模式中服务器端和客户端之间进行实时异步通信。 众所周知&#xff0c;传统的HTTP协议中&#xff0c;服务器端和客户端通信只能是在客户端发送一个请求之后&#xff0c;服务器端…

多线程和多进程的区别(小结)

分类&#xff1a; linux 2009-06-19 09:33 11501人阅读 评论(15) 收藏 举报 很想写点关于多进程和多线程的东西&#xff0c;我确实很爱他们。但是每每想动手写点关于他们的东西&#xff0c;却总是求全心理作祟&#xff0c;始终动不了手。 今天终于下了决心&#xff0c;写点东西…

redis-cli使用密码登录

redis-cli使用密码登录 注意IP地址要写正确&#xff01; 学习了: https://blog.csdn.net/lsm135/article/details/52932896 https://blog.csdn.net/zyz511919766/article/details/42268219 https://zhidao.baidu.com/question/756651357338691604.html 登录后 auth pass 或者 r…

FFT快速傅式变换算法halcon算子,持续更新

目录convol_fftconvol_gaborcorrelation_fftdeserialize_fft_optimization_dataenergy_gaborfft_genericfft_imagefft_image_invgen_bandfiltergen_bandpassgen_derivative_filtergen_filter_maskgen_gaborgen_gauss_filtergen_highpassgen_lowpassgen_mean_filtergen_sin_band…

仿照vue实现简易的MVVM框架(一)

代码github地址&#xff1a; https://github.com/susantong/myMVVM 主要的方法有&#xff1a; compile 深度遍历前端界面的节点&#xff0c;将其复制进一个addQuene队列中pasers 遍历所有的节点&#xff0c;并将节点包装成一个含有本节点、自定义属性及属性值的对象。要想实现双…

tomcat 启动时内存溢出

在tomcat_home/bin目录下找到catalina.bat&#xff0c;用文本编辑器打开&#xff0c;加上下面一行&#xff1a; set JAVA_OPTS -Xms1024M -Xmx1024M -XX:PermSize256M -XX:MaxNewSize256M -XX:MaxPermSize256M 解释一下各个参数&#xff1a; -Xms1024M&#xff1a;初始化堆内存…

@angular/platform-browser-dynamic

/** experimental */ export declare class JitCompilerFactory implements CompilerFactory {createCompiler(options?: CompilerOptions[]): Compiler; }export declare const platformBrowserDynamic: (extraProviders?: StaticProvider[] | undefined) > PlatformRef;…

牛人项目失败的总结

tom_lt: 遇到的失败项目比较多&#xff01;让人郁闷&#xff01;&#xff01; 仔细分析原因&#xff0c;主要在于&#xff1a; 1.项目开始需求不明确。领导决定动手&#xff0c;就开始启动项目&#xff0c;造成和客户需要差距太大&#xff0c;导致失败&#xff1b; 2.需求变更没…

Android:日常学习笔记(8)———探究UI开发(5)

Android:日常学习笔记(8)———探究UI开发(5) ListView控件的使用 ListView概述 A view that shows items in a vertically scrolling list. The items come from the ListAdapter associated with this view. 1.关于ArrayAdapter&#xff1a; ArrayAdapter<T> 是 ListAd…

Geometric-Transformations图像几何变换halcon算子,持续更新

目录affine_trans_imageaffine_trans_image_sizeconvert_map_typemap_imagemirror_imagepolar_trans_image_extpolar_trans_image_invprojective_trans_imageprojective_trans_image_sizerotate_imagezoom_image_factorzoom_image_sizeaffine_trans_image 功能&#xff1a;把任…

hibernate inverse属性的作用

hibernate配置文件中有这么一个属性inverse&#xff0c;它是用来指定关联的控制方的。inverse属性默认是false&#xff0c;若为false&#xff0c;则关联由自己控制&#xff0c;若为true&#xff0c;则关联由对方控制。见例子&#xff1a; 一个Parent有多个Child,一个Child只能有…

分布式锁与实现(一)——基于Redis实现

概述 目前几乎很多大型网站及应用都是分布式部署的&#xff0c;分布式场景中的数据一致性问题一直是一个比较重要的话题。分布式的CAP理论告诉我们“任何一个分布式系统都无法同时满足一致性&#xff08;Consistency&#xff09;、可用性&#xff08;Availability&#xff09;和…

浅析软件项目管理中十个误区(来自:http://manager.csdn.net/n/20051213/30907.html)

随着计算机硬件水平的不断提高&#xff0c;计算机软件的规模和复杂度也随之增加。计算机软件开发从“个人英雄”时代向团队时代迈进&#xff0c;计算机软件项目的管理也从“作坊式”管理向“软件工厂式”管理迈进。这就要求软件开发人员特别是软件项目管理人员更深一步地理解和…

俩孩随笔

俩孩随笔 有人给我贴了技术男加奶爸的标签&#xff0c;不过这两项都不是我的强项。我深知自己最大的长处在哪&#xff1a;普通&#xff0c;扔人堆里&#xff0c;不是认不出来&#xff0c;而是压根看不着。想把事情做好&#xff0c;常常会用力过度。工作平平淡淡&#xff0c;需…

Inpainting图像修复halcon算子,持续更新

目录harmonic_interpolationinpainting_anisoinpainting_cedinpainting_ctinpainting_mcfinpainting_textureharmonic_interpolation 功能&#xff1a;对一个图像区域执行谐波插值。 inpainting_aniso 功能&#xff1a;通过各向异性扩散执行图像修复。 inpainting_ced 功能…

算法(伪代码)的书写

q ⇒ Queue&#xff08;队列&#xff09;, s ⇒ Set&#xff08;集合&#xff09;pq ⇒ PriorityQueue&#xff08;优先队列&#xff09;d ⇒ distance1. initialization 变量&#xff0c;数据结构的定义&#xff0c;及初始值的赋值&#xff1b;比如著名的 Dijkstra &#xff0…

第八次作业——系统设计与团队分配(个人)

团队作业地址&#xff1a;https://www.cnblogs.com/clio-hhhhhhl/p/9079157.html 个人码云地址&#xff1a;https://gitee.com/Cliohl/events 团队码云地址&#xff1a;https://gitee.com/Cliohl/zhuoyue 项目进展&#xff1a; 上礼拜进展&#xff1a;把部分前端页面实现出来&a…

深入理解Activity启动流程(二)–Activity启动相关类的类图

本文原创作者:Cloud Chou. 欢迎转载&#xff0c;请注明出处和本文链接 本系列博客将详细阐述Activity的启动流程&#xff0c;这些博客基于Cm 10.1源码研究。 在介绍Activity的详细启动流程之前&#xff0c;先为大家介绍Activity启动时涉及到的类&#xff0c;这样大家可以有大概…