Java進程占用CPU資源過多分析

問題描述:
生產環境下的某臺tomcat7服務器,在剛發布時的時候一切都很正常,在運行一段時間后就出現CPU占用很高的問題,基本上是負載一天比一天高。
問題分析:
1,程序屬于CPU密集型,和開發溝通過,排除此類情況。
2,程序代碼有問題,出現死循環,可能性極大。
問題解決:
1,開發那邊無法排查代碼某個模塊有問題,從日志上也無法分析得出。
2,記得原來通過strace跟蹤的方法解決了一臺PHP服務器CPU占用高的問題,但是通過這種方法無效,經過google搜索,發現可以通過下面的方法進行解決,那就嘗試下吧。
解決過程:
1,根據top命令,發現PID為2633的Java進程占用CPU高達300%,出現故障。
2,找到該進程后,如何定位具體線程或代碼呢,首先顯示線程列表,并按照CPU占用高的線程排序:
[root@localhost logs]# ps -mp 190102633 -o THREAD,tid,time | sort -rn
顯示結果如下:
USER???? %CPU PRI SCNT WCHAN? USER SYSTEM?? TID???? TIME
root???? 10.5? 19??? - -???????? -????? -? 190103626 00:12:48
root???? 10.1? 19??? - -???????? -????? -? 190103593 00:12:16
找到了耗時最高的線程190123626,占用CPU時間有12分鐘了!
將需要的線程ID轉換為16進制格式:
[root@localhost logs]# printf "%x\n" 3626
e18
最后打印線程的堆棧信息:
[root@localhost logs]# jstack 2633 |grep 4a44e18 -A 30
將輸出的信息發給開發部進行確認,這樣就能找出有問題的代碼。

http://blog.chinaunix.net/uid-10449864-id-3463151.html

轉載于:https://www.cnblogs.com/Viguss/p/4533566.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/258849.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/258849.shtml
英文地址,請注明出處:http://en.pswp.cn/news/258849.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

分針網——怎么輕松學習JavaScript

js給初學者的印象總是那么的“雜而亂”,相信很多初學者都在找輕松學習js的途徑。我試著總結自己學習多年js的經驗,希望能給后來的學習者探索出一條“輕松學習js之路”。js給人那種感覺的原因多半是因為它如下的特點:A:本身知識很抽…

MATLAB中floor、round、ceil、fix區別

Matlab取整函數有: fix, floor, ceil, round.具體應用方法如下:fix朝零方向取整,如fix(-1.3)-1; fix(1.3)1;floor,顧名思義,就是地板,所以是取比它小的整數,即朝負無窮方向取整,如floor(-1.3)-2…

python時間序列分析航空旅人_用python做時間序列預測一:初識概念

利用時間序列預測方法,我們可以基于歷史的情況來預測未來的情況。比如共享單車每日租車數,食堂每日就餐人數等等,都是基于各自歷史的情況來預測的。 什么是時間序列? 時間序列,是指同一個變量在連續且固定的時間間隔上…

解決mysql不能遠程登入的問題

mysql遠程不能登入,問題就在于當時設置的賬號只限制本地訪問,mysql默認也只是本地訪問。之前的設置: 通過命令行登錄管理MySQL服務器(提示輸入密碼時直接回車): mysql> /usr/local/webserver/mysql/bin/…

ASCII碼、HEX、字符、BCD 等等 基礎知識思考

每每遇到這些問題就要想個半天,想不明白還不舒服,今天特別把所想整理下避免以后再次進入思想漩渦!!!計算機存儲和傳輸都是以字節為單位 1 bit 1 二進制數據 1 byte 8 bit 1 字母 1 by…

[Logstash-input-redis] 使用詳解

2019獨角獸企業重金招聘Python工程師標準>>> Redis插件參數配置詳解 工作流程 logstash啟動redis插件redis插件獲取參數,進行校驗工作判斷監聽模式(list,channel,pattern_channel等),根據不同的監聽模式創建監聽任務創建redis實例&#xff0c…

雅可比旋轉求解對稱二維矩陣的特征值和特征向量

問題描述: 給定一個矩陣,如下: A[a11a21a12a22]A=\begin{bmatrix} a_{11}&a_{12}\\ a_{21}& a_{22} \end{bmatrix} 其中滿足a12a21.也就是所謂的 對稱矩陣。那么如何求解此矩陣的特征值以及特征向量呢?這里我們要用到 …

游戲場景燈光烘焙

【LV4】北京 天殺神(153478394) 10:21:15可能是我找的截圖不好 我就是想問下 一般要烘焙這樣的一個場景的步驟是什么 【LV5】北京地編~mr(274380109) 10:21:44首先就看原畫的色調 確定一個環境光如果是晴天 就打一個直光 給陰影 直光不要太亮 【LV5】北京地編&a…

python畫圖數據的平均值怎么算的_Python氣象數據處理與繪圖(2):常用數據計算方法...

對于氣象繪圖來講,第一步是對數據的處理,通過各類公式,或者統計方法將原始數據處理為目標數據。 按照氣象統計課程的內容,我給出了一些常用到的統計方法的對應函數: import numpy as np 平均值 在計算氣候態&#xff0…

Linux下nginx安裝與配置

部分Linux發布版的默認安裝已經集成了nginx,查看方法ls /usr/local,若已有nginx文件夾說明已集成。nginx依賴庫pcre與zlib,且pcre依賴于gcc與gcc-c,因此安裝步驟為:安裝gcc與gcc-c庫安裝pcre庫安裝zlib庫安裝nginx詳細…

java 讀取properties文件

1.不在項目中讀取 Properties properties new Properties();BufferedReader read new BufferedReader(new InputStreamReader(new FileInputStream("文件的路徑"),"utf-8"));properties.load(read);properties .getProperty("那個文件的key") …

幾種字符串加密解密的方法

為什么80%的碼農都做不了架構師?>>> 第一種:〔 Python 與 Bash Shell 的結合 〕 這個命令會讓你輸入一個字符串,然后會再輸出一串加密了的數字。 加密代碼[照直輸入]: python -c print reduce(lambda a,b: a*256ord(b), raw_inpu…

java delegate怎么寫_美團面試官:你說你們公司的Mybatis分頁插件是你寫的,給我說說它的設計原理?...

來源:http://my.oschina.net/zudajun大多數框架,都支持插件,用戶可通過編寫插件來自行擴展功能,Mybatis也不例外。我們從插件配置、插件編寫、插件運行原理、插件注冊與執行攔截的時機、初始化插件、分頁插件的原理等六個方面展開…

C++標準庫與Java基礎類對照表

一、集合類對象的集合,指如鏈表,數組,隊列這一類的數據結構。在C標準庫中把這些成為Container, 在Java中稱為Collection。CSTL常用Container: vector, list, map, set, queue, stack, priority_queueJava基礎類:ArrayL…

ASP.NET MVC 在控制器中獲取某個視圖動態的HTML代碼

如果我們需要動態的用AJAX從服務器端獲取HTML代碼,拼接字符串是一種不好的方式,所以我們將HTML代碼寫在cshtml文件中,然后通過代碼傳入model,動態獲取cshtml中的HTML代碼 當然,我們想要使用通用的方法去獲取cshtml&…

SharePoint 2013 處理videoplayerpage.aspx下的個人圖片顯示有誤問題

問題:Personal sites photo cant correct display in the videos pageThe url address of personal sites photo is exist surplus characters. The correct situation is just the characters of "%20", not the characters of "%2520".解決方…

Python學習筆記(一)

1.python語言的優點:(1)是一種高級語言,提供大量的庫和內置數據結構(2)書寫簡潔優美 缺點:是解釋性語言,執行速度較慢 2.從官方網站下載的python解釋器為CPython,是一種用C語言編寫的python解釋器。在命令行如果啟動python3,輸入p…

匯編語言基本概念匯總

匯編語言應該是我們如今學的最“低級”的語言了,由于如今不會再有人去學機器語言了。而匯編語言還在一些硬件或者嵌入式設備上使用并開發著。下面資料是為了大學的匯編考試整理的資料,如今與大家分享,希望能給大家提供幫助。 匯編語言程序設計…

MySQL找出鎖等待

1.服務器級別的鎖等待可以通過show processlist看到等待鎖的線程id,但是無法知道究竟哪個線程持有鎖可以通過mysqladmin debug相關等待鎖的線程以及誰持有鎖可以在錯誤日志中找到2.存儲引擎層的鎖等待則比較麻煩,以下是innodb存儲引擎中鎖等待以及哪個線…

C++給函數傳數組參數C++給函數傳數組參數

C給函數傳數組參數 在C中&#xff0c;如果要給一個函數傳入一個數組&#xff0c;一般都是傳入兩個參數一個數組指針和一個數組大小 例&#xff1a; void print_1 (int n, int *datas ) { for (int i 0; i < n; i) { std::cout << datas[i] <<…