Java進(jìn)程cpu占用過(guò)高問(wèn)題解決
cpu是時(shí)分(time division)的,操作系統(tǒng)里有很多線程,每個(gè)線程的運(yùn)行時(shí)間由cpu決定,cpu會(huì)分給每個(gè)線程一個(gè)時(shí)間片,時(shí)間片是一個(gè)很短的時(shí)間長(zhǎng)度,如果在時(shí)間片內(nèi),線程一直占有,則是100%;我們應(yīng)該意識(shí)到,cpu運(yùn)行速度很快(主頻非常高),除非密集型耗費(fèi)cpu的運(yùn)算,其它類型任務(wù)都會(huì)在小于時(shí)間片的時(shí)間內(nèi)結(jié)束。
產(chǎn)生CPU100%的原因:
某一程序一直占用CPU是導(dǎo)致CPU100%的原因,大概有以下幾種情況:
1、Java 內(nèi)存不夠或溢出導(dǎo)致GC overhead問(wèn)題, GC overhead 導(dǎo)致的CPU 100%問(wèn)題;
2、死循環(huán)問(wèn)題. 如常見(jiàn)的HashMap被多個(gè)線程并發(fā)使用導(dǎo)致的死循環(huán), 或者死循環(huán);
3、某些操作一直占用CPU
第一步:使用top命令,查看占用cpu的進(jìn)程
[root@sdfsdfseZ codeimage]# top

第二步:ps -ef | grep java 或jps命令,找出服務(wù)器的所有java進(jìn)程

第三步:找出CPU耗用最厲害的進(jìn)程pid

第四步:查找出具體占用cpu利用率最厲害的線程號(hào),top -H -p pid 。然后按下shift+p,跳出CPU監(jiān)控
當(dāng)前線程號(hào)為:1747

第五步:將獲取到的線程號(hào)轉(zhuǎn)換成16進(jìn)制
因?yàn)閖ava線程棧文件中的線程id是十六進(jìn)制,需要將線程id從十進(jìn)制轉(zhuǎn)為十六進(jìn)制。十進(jìn)制 轉(zhuǎn)十六進(jìn)制的命令如下:
結(jié)果為:

第六步:導(dǎo)出線程棧
將具體的占用CPU過(guò)高的java進(jìn)程的線程棧導(dǎo)出,導(dǎo)出命令如下:
pid.tdump文件后綴名隨意,通常以tdump結(jié)尾。
[root@sdfsdfsdeZ codeimage]# jstack 1747 > tmp/1747.tdump

可能會(huì)拋出異常;
1747: Unable to open socket file: target process not responding or HotSpot VM not loaded
The -F option can be used when the target process is not responding
原因分析
jvm運(yùn)行時(shí)會(huì)生成一個(gè)目錄hsperfdata_$USER($USER是啟動(dòng)java進(jìn)程的用戶),在linux中默認(rèn)是/tmp,目錄下會(huì)有些pid文件,存放jvm進(jìn)程信息,而jmap,jstack等工具會(huì)讀取/tmp/hsperfdata_$USER下的pid文件獲取連接信息.
檢查了/tmp/hsperfdata_root目,,但在$TOMCAT_HOME目錄中的temp目錄中有對(duì)應(yīng)的文件.
解決辦法
使用
[root@iZ2zeab8t820b5ywp0rkfeZ bin]# jstack 1706 > /tmp/hsperfdata_root/1706.tdump
第七步:導(dǎo)出堆
[root@sddsdfsaZ bin]# jstat -gcutil 1706

第八步:jvisualvm分析快照使用JAVA_HOME/bin/jvisualvm.exe,載入快照
文件----->載入—>文件類型(Dump)

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
獲取Java線程轉(zhuǎn)儲(chǔ)的常用方法(推薦)
這篇文章主要介紹了獲取Java線程轉(zhuǎn)儲(chǔ)的常用方法,本文給大家介紹的非常想詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
Java 如何實(shí)現(xiàn)照片轉(zhuǎn)化為回憶中的照片
本文主要介紹了可以對(duì)圖片進(jìn)行色彩處理的Java工具類,讓圖片變成回憶中的畫(huà)面,主要將圖片做黑白與褐色的處理。代碼具有一定價(jià)值,感興趣的童鞋可以關(guān)注一下2021-11-11
spring配置定時(shí)任務(wù)的幾種方式總結(jié)
這篇文章主要介紹了spring配置定時(shí)任務(wù)的幾種方式總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
基于java SSM springboot實(shí)現(xiàn)景區(qū)行李寄存管理系統(tǒng)
這篇文章主要介紹了基于java SSM springboot實(shí)現(xiàn)的景區(qū)行李寄存管理系統(tǒng),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08
java中BeanUtils.copyProperties的用法(超詳細(xì))
本文介紹了BeanUtils.copyProperties()方法的使用,包括其功能、用法、注意事項(xiàng)和示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08
Java編寫(xiě)日志手機(jī)號(hào)脫敏工具類
在開(kāi)發(fā)過(guò)程中,很容易將用戶敏感信息,例如手機(jī)號(hào)碼、身份證等,打印在日志平臺(tái),本文將利用Java編寫(xiě)一個(gè)日志手機(jī)號(hào)脫敏工具類,感興趣的可以了解下2024-12-12
Java8新特性之重復(fù)注解(repeating annotations)淺析
這篇文章主要介紹了Java8新特性之重復(fù)注解(repeating annotations)淺析,這個(gè)新特性只是修改了程序的可讀性,是比較小的一個(gè)改動(dòng),需要的朋友可以參考下2014-06-06
MyBatis-Plus實(shí)現(xiàn)2種分頁(yè)方法(QueryWrapper查詢分頁(yè)和SQL查詢分頁(yè))
本文主要介紹了MyBatis-Plus實(shí)現(xiàn)2種分頁(yè)方法,主要包括QueryWrapper查詢分頁(yè)和SQL查詢分頁(yè),具有一定的參考價(jià)值,感興趣的可以了解一下2021-08-08

