java cpu高_Java中的CPU占用高和内存占用高的问题排查

下面通过模拟实例分析排查Java应用程序CPU和内存占用过高的过程。如果是Java面试,这2个问题在面试过程中出现的概率很高,所以我打算在这里好好总结一下。

1、Java CPU过高的问题排查

举个例子,如下:

package com.classloading;

public class Test {

static class MyThread extends Thread {

public void run() { // 死循环,消耗CPU

int i=0;

while (true) {

i++;

}

}

}

public static void main(String args[]) throws InterruptedException {

new MyThread().start();

Thread.sleep(10000000);

}

}

使用top命令查看占用CPU过高的进程。如下图所示。

01276a3246db6ee842903fd5aec96206.png

查看进程6102下线程的占用情况,如下图所示。

15fb6e1fc15fef13a8e10486d4b0b637.png

使用如下命令将6122转换为16进制表示,如下:

15f7af8b80192439ff339f6df85be9d1.png

导出CPU占用高进程的线程栈。命令如下:

jstack pid>>java.txt

内容如下:

mazhi@mazhi:~$ cat java.txt

Attaching to remote server pid, please wait...

2021-02-23 15:38:18

Full thread dump Java HotSpot(TM) 64-Bit Server VM (25.192-b12 mixed mode):

"Attach Listener" #10 daemon prio=9os_prio=0tid=0x00007f4ee0001000nid=0x1956runnable [0x0000000000000000]

java.lang.Thread.State: RUNNABLE

// 这是0x17ea线程,也是占用CPU最高的线程

"Thread-0" #9 prio=5os_prio=0tid=0x00007f4f180d6000nid=0x17earunnable [0x00007f4f044da000]

java.lang.Thread.State: RUNNABLE

at com.cpuhigh.Test$MyThread.run(Test.java:8)  // 这里指示第8行,则正是死循环的代码开始

...

导出的堆栈信息有线程的状态(一般要找RUNNABLE状态)和调用堆栈结合来查找问题。线程dump分析:线程dump分析主要目的是定位线程长时间停顿的原因

c9cede1e6255da3fc3908f4db48ba7c4.png

2、Java 内存过高的问题排查

举个例子如下:

package com.classloading;

import java.util.ArrayList;

import java.util.List;

public class Test {

private static final int UNIT_MB=1024* 1024;

public static void main(String args[]) throws InterruptedException{

Listx=newArrayList();

int i=0;

while(i<1000){

x.add(new byte[UNIT_MB]);

i++;

}

Thread.sleep(1000000000);

}

}

通过jmap dump内存快照。 如果是线上环境,注意dump之前必须先将流量切走,否则大内存dump是直接卡死服务。

命令行输入:

jmap -histo| head -20

就可以查看某个pid的java服务占用内存排名前20的类,如下图所示。

5d5bb6ec5400d486445657d4e8692178.png

可以看到,占用内存最多的是byte字节数组,共有1008个实例。

jmap 还有一个指令可以把整个内存情况转成文件形式保存下来,如下:

jmap-dump:format=b,file=filename.bin

执行命令如下图所示。

67f73367197a9333a17432c0152fccba.png

可以在JVM启动时设置,如果发生OOM,则dump出文件。命令如下:

-XX:+HeapDumpOnOutOfMemoryError-XX:HeapDumpPath=/tmp/heapdump.hprof

如果快照文件不大,可以下载到本地,然后通过 MAT 分析,也可以在线分析( https://fastthread.io/ );如果快照文件很大,可以在服务器上直接分析,使用的命令是:

jhat dump.hprof

jhat也是jdk内置的工具之一。主要是用来分析java堆的命令,可以将堆中的对象以html的形式显示出来,包括对象的数量,大小等等,并支持 对象查询语言 。命令执行后如下图所示。

3d634c7986a0fc2b923ea284635adb08.png

访问如下图所示。

d2671744bf670c899fbb5b6306441d60.png

其中的Show heap histogram就会显示对象占用内在的大小。如下图所示。

d8e3057658bd40e1d5797bead6a6ee36.png

【责任编辑:庞桂玉 TEL:(010)68476606】

点赞 0

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

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

相关文章

solr 时间转成java_solr时区设置解决时间多8小时问题

今天发现我博客里文章的时间与实际时间差了8小时&#xff0c;正好比原来时间多出8小时&#xff0c;想想应该是时区不一致的问题。用solr web工具查询出来的数据原样&#xff1a;"create_time": "2018-01-18T11:22:06Z"{"original": 1,"crea…

php if 单行,php – 单行if语句或if语句没有大括号坏习惯?

最好的做法是编写别人可以轻松读取和更新的代码。您的第一个表单是有问题的&#xff0c;因为它不遵循大多数PHP开发人员使用的表单&#xff1a;if (condition) {// code} else {// code}// ... or ...if (condition){// code}else{// code}// ... or ...if (condition) { /* sh…

php 错误 异常,php中的异常和错误解析

PHP错误是属于php程序自身的问题&#xff0c;一般是由非法的语法&#xff0c;环境问题导致的&#xff0c;使得编译器无法通过检查甚至无法运行的情况。PHP异常一般是业务逻辑上出现的不合预期、与正常流程不同的状况&#xff0c;不是语法错误。本文介绍了php中异常和错误的相关…

php变量原格式输出,PHP格式化输出打印变量

PHP 常用的输入变量函数print_r&#xff0c;但是输出没有换行&#xff0c;看起来很费力 我们可以自定义一个函数来实现变量的格式化输出&#xff0c;代码如下&#xff1a; function dump($vars, $label , $return false) {if (ini_get(html_errors)) {$content "\n&quo…

一个控制器2套模版php,如何不用一个自定义的控制器渲染一个模板

如何不用一个自定义的控制器渲染一个模板通常&#xff0c;当您需要创建一个页面&#xff0c;您需要创建一个控制器并且从该控制器中呈现模板。但如果您仅仅呈现一个简单的模板&#xff0c;并且不需要传递给它的任何数据&#xff0c;则完全没必要创建一个控制器&#xff0c;通过…

JAVA语言写的,用java语言写

Caballariistatic int argument;static int count0;public static void main(String[] args){argument5;printResult("",argument);System.out.println("总共"count"种");}public static void printResult(String result,int left){if(left1){Sy…

accept标头 php,解决PHP中缺少“授权”请求标头的问题

我目前正在为一个uni项目开发PHP REST API,该项目使用通过PhoneGap从移动Web应用程序传递的JSON Web令牌,或者在开发过程中使用我的桌面.使用ajax将令牌发送到我的服务器页面“ friends / read.PHP”时,服务器使用以下命令正确获取了Authorization标头$headers getallheaders(…

handsome对应php文件,基于handsome主题的一些美化总结

用了handsome主题有一段时间了&#xff0c;挺不错的主题!在无数次更换各种博客程序后最终还是选择使用Typecho&Handsome主题搭建博客如果长久发展的话建议就用wordpress进入正题:代码没标明的都是添加至handsome主题后台主题设置 自定义CSS。首页头像转动并放大.thumb-lg{w…

php语录网站,杨泽业:给你的wordpress博客添加经典语录功能,适合所有php网站

我们做一个网站就是要不断给访客提供最佳的用户体验&#xff0c;同时提升自己的品牌价值&#xff0c;而文章结束的经典语录的功能&#xff0c;完全可以实现我们所要达到的效果。(如下图)给你的wordpress博客添加经典语录功能这个是怎样实现的呢&#xff1f;其实很简单&#xff…

matlab搭建的应用层架构逻辑,软件设计的三层架构

1&#xff1a;三层架构是什么&#xff1f;三层架构是一个分层式的软件体系架构设计理念。把软件架构分为三层&#xff1b;1&#xff1a;UI层 (user interface layer) 界面层2&#xff1a;BLL层 (business logic layer) 业务逻辑层3&#xff1a;DAL层 (data access laye…

mysql null 0 空,MySQL的空值和NULL区别

从本质上区别&#xff1a;1、空值不占空间2、null值占空间通俗的讲&#xff1a;空值就像是一个真空转态杯子&#xff0c;什么都没有&#xff0c;而null值就是一个装满空气的杯子&#xff0c;虽然看起来都是一样的&#xff0c;但是有着本质的区别。例子&#xff1a;创建一个test…

mysql 数据库中数据去重,oracle数据库中如何达到像mysql数据库中group by 那种去重的效果..求大神解答...

满意答案oracle和mysql&#xff0c;group by是由区别的。oracle的gruop by 后跟的必须是select查询出的字段而且group by语句中select指定的字段必须是“分组依据字段”&#xff0c;其他字段若想出现在select中则必须包含在聚合函数中聚合函数比如&#xff1a;sum(列名) 求和ma…

强制关机对电脑的影响_笔记本电脑需要每天关机吗?长期开机对电脑有影响么?...

笔者之前写过一些选购笔记本的文章&#xff0c;就有不少网友问了这个问题&#xff1a;笔记本电脑需要每天关机么&#xff1f;一直开着有没有问题&#xff1f;这里说得一直开着是选择了合盖睡眠(或者休眠)的方式。使用时翻开笔记本盖子就可以工作&#xff0c;工作做完后合上盖子…

matlab 矩阵与向量乘,matlab问题,关于矩阵向量的乘问题

问题描述&#xff1a;matlab问题,关于矩阵向量的乘问题mxwtbx*T;mywtby*T;mzwtbz*T;%%%通过四元素解微分方程pmx.^2my.^2mz.^2;//这个地方有问题,我在下面说a1-p/8;b0.5-p/48;c(1)b*(a*q(1)/b-mx*q(2)-my*q(3)-mz*q(4));//提示这里有问题.c(2)b*(mx*q(1)a*q(2)/bmz*q(3)-my*q(4…

python关闭exe程序_Win 10 中使用 Python 碰到的奇怪现象

优质文章&#xff0c;第一时间送达&#xff01;作者&#xff1a;流光飞舞来源&#xff1a;https://shuhari.dev/blog/2019/11/win10-store-python最近在使用 Python 的时候发生了很奇怪的现象&#xff1a;从命令行执行 python.exe并不会进入 REPL&#xff0c;似乎也没有其他反应…

Matlab语音采集与读写程序,基于MATLAB的语音信号录制采集和分析的程序设计

理 论广 角 ● I 基于 MATLAB的语音信号录制采集和分析的程序设计 刘 晓炯 (西北民族大学电气工程学院 甘肃 兰州I 730030) [摘 要]语音信号处理技术是语音处理领域中新近发展起来的一个学科分支&#xff0c;MATLAB是一个数据分析和处理功能十分强大的工程使用软件&#xff0c;…

mulitpartfile怎么接收不到值_手机有时接收不到微信消息通知,怎么办?超全解决方案...

不知道大家在使用微信的过程中有没有遇到以下情况&#xff0c;在自己看视频或者刷其他网页的时候&#xff0c;没有接收到微信的任何通知和提示的消息。等到你进入微信页面后&#xff0c;突然发现有很多未读信息。这种情况时有发生&#xff0c;很多人都反应说微信接收消息总是会…

生活 list.php,list.php

require_once config.php;// 接收传来的分类id$categoryId$_GET[categoryId];//3// 查询当前分类下的文章// echo $categoryId;// 连接数据库$connectmysqli_connect(DB_HOST,DB_USER,DB_PWD,DB_NAME);// 写sql$sql"select p.id,p.title,p.feature,p.content,p.created,p.…

苹果呼叫转移设置不了_怎么设置别人电话打不进来

您可以尝试输入【**21*888888#】并按下拨打键&#xff0c;开启本机的呼叫转移功能&#xff0c;在开启之后别人拨打您的电话会转移到888888这个空号&#xff0c;实现别的电话无法打入的效果。以下就是相关的步骤介绍&#xff1a;1、只需要在安卓或者苹果iOS 11系统的手机的拨号界…

apache php日志配置,HTML_初学:apache与php基本配置,1、APACHE的日志主要分为“ - phpStudy...

1、APACHE的日志主要分为“错误日志”与“访问日志”。2、apache错误日志目录的设置&#xff1a;/etc/apache2/apache2.conf 约170行左右ErrorLog /var/log/apache2/error.log 错误日志将保存在error.log中ErrorLog /dev/null / 将错误日志指向空设备&#xff0c;那么就等于…