成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

應(yīng)用服務(wù)器發(fā)生內(nèi)存溢出怎么辦?兩個(gè)工具幫你解決問題

開發(fā) 開發(fā)工具
內(nèi)存溢出最常見的原因解決起來也最麻煩,本文主要描述這類內(nèi)存溢出問題如何進(jìn)行分析和定位。

問題描述

對(duì)于B/S架構(gòu)的J2EE應(yīng)用系統(tǒng),應(yīng)用服務(wù)器發(fā)生內(nèi)存溢出(OutOfMemoryError)錯(cuò)誤是非常棘手的問題,解決問題的關(guān)鍵是要定位哪里出了問題。一般內(nèi)存溢出的原因有以下幾類:

Jvm內(nèi)存參數(shù)設(shè)置不合理

如:

  • -Xmx設(shè)置的比較小
  • -Xms設(shè)置的過大
  • sun的jvm沒有設(shè)置
  • -XX:MaxPermSize大小等等

由于參數(shù)設(shè)置問題導(dǎo)致的內(nèi)存溢出往往容易發(fā)現(xiàn),調(diào)整一下參數(shù),問題基本就可以解決。

應(yīng)用服務(wù)器缺少必要的補(bǔ)丁

例如Websphere的某些版本存在很多性能缺陷,某些情況下也會(huì)導(dǎo)致內(nèi)存溢出,打上補(bǔ)丁后,問題基本可以得到解決。

應(yīng)用程序代碼存在缺陷

此類問題是內(nèi)存溢出最常見的原因,解決起來也最麻煩,本文主要描述這類內(nèi)存溢出問題如何進(jìn)行分析和定位。

解決方案

工欲善其事,必先利其器,有了好的工具,解決問題往往能起到事半功倍的作用,很多時(shí)候沒有工具支持,問題很難解決。

本文主要涉及到2個(gè)工具的運(yùn)用:

  • 分析JavaCore的工具:IBM Thread and Monitor Dump Analyzer for Java。
  • 分析Heapdump的工具:Eclipse Memory Analyzer。

通過這2個(gè)工具,一般的內(nèi)存溢出問題基本可以定位。

在介紹這2個(gè)工具之前,先對(duì)一些相關(guān)概念做下解釋說明:

Heapdump

某一時(shí)刻Java進(jìn)程內(nèi)存的快照,記錄當(dāng)時(shí)內(nèi)存中各對(duì)象的存儲(chǔ)和引用關(guān)系等。Heapdump中不包含對(duì)象的調(diào)用信息,即無法從Heapdump中看出某個(gè)對(duì)象是哪段程序代碼生成出來的。

JavaCore

某一時(shí)刻Java進(jìn)程中線程的快照,記錄當(dāng)時(shí)所有線程的執(zhí)行堆棧信息等。JavaCore中可以看到各線程都在處理哪些程序代碼,可以看到當(dāng)前Java都在“做什么事”,在線程的執(zhí)行堆棧中,有代碼的調(diào)用信息,也有對(duì)象生成的相關(guān)信息等。

兩種內(nèi)存溢出

內(nèi)存溢出一般分兩種,內(nèi)存使用過度和內(nèi)存泄露。

  • 使用過度指在短時(shí)間內(nèi)急劇耗盡大量內(nèi)存導(dǎo)致內(nèi)存溢出。
  • 內(nèi)存泄露指長時(shí)間內(nèi),內(nèi)存逐漸耗盡導(dǎo)致內(nèi)存溢出,時(shí)間可能是幾個(gè)小時(shí)或幾天(通過開啟詳細(xì)垃圾回收可以清晰地觀察到內(nèi)存的分配情況)。

Java系統(tǒng)的內(nèi)存溢出大部分都是由于內(nèi)存使用過度導(dǎo)致,內(nèi)存泄露比較少見。本文后面介紹的也都是關(guān)于內(nèi)存使用過度導(dǎo)致內(nèi)存溢出的分析方法。

對(duì)于內(nèi)存使用過度導(dǎo)致的內(nèi)存溢出,可以通過Heapdump和JavaCore結(jié)合分析定位問題,對(duì)于內(nèi)存泄露,主要還是分析Heapdump。

當(dāng)Java進(jìn)程出現(xiàn)內(nèi)存溢出錯(cuò)誤時(shí),通常會(huì)生成Heapdump文件和JavaCore文件,例如Websphere部署的web應(yīng)用,當(dāng)出現(xiàn)內(nèi)存溢出時(shí),會(huì)在如下目錄

/opt/IBM/WebSphere/AppServer/profiles/server1看到出現(xiàn)類似這樣的文件:

Heapdump.*.phd文件記錄Heapdump信息,javacore.*.txt記錄JavaCore信息,一般內(nèi)存溢出時(shí)會(huì)出現(xiàn)多個(gè)phd文件和JavaCore文件,分析時(shí)用其中一個(gè)即可。

下面就介紹如何通過工具分析這2個(gè)文件,如何通過對(duì)這2個(gè)文件的分析定位出內(nèi)存溢出(內(nèi)存使用過度導(dǎo)致)的原

1. 分析 javacore

Javacore 的分析工具 IBM Thread and Monitor Dump Analyzer for Java(簡稱 JCA),以圖形化的方式展現(xiàn) java 線程的堆棧信息及相互關(guān)系等。下面是工具使用的截圖:

對(duì)于 Websphere,主要關(guān)注 WebContainer 線程的執(zhí)行堆棧情況,上圖顯示W(wǎng)ebContainer:57 號(hào)線程的執(zhí)行堆棧。Javacore 文件本身就是個(gè)文本文件,直接通過文本編輯器如 editplus 也可以打開,下面是用文本編輯器打開 javacore 文件后看到的WebContainer:57 號(hào)線程的執(zhí)行堆棧:

可以看到,通過 JCA 打開 javacore 和通過 editplus 打開 javacore,沒有本質(zhì)的區(qū)別,只是展現(xiàn)形式有所區(qū)別而已,有關(guān) JCA 工具的具體使用這里不作詳細(xì)介紹。分析 javacore的重點(diǎn)是根據(jù)每個(gè)線程的堆棧信息找出哪個(gè)或哪幾個(gè)線程導(dǎo)致 java 進(jìn)程的內(nèi)存溢出,對(duì)應(yīng)線程堆棧中的代碼段就是罪魁禍?zhǔn)住@?,如果通過分析得到 WebContainer:57 號(hào)線程可能導(dǎo)致內(nèi)存溢出,那么 57 號(hào)線程中的這段代碼就是問題所在。

為什么是 WebContainer:57 號(hào)線程有問題,而不是其它線程呢?這就需要結(jié)合heapdump 進(jìn)行綜合分析,下面會(huì)有詳細(xì)介紹。

2. 分析 Heapdump

Heapdump 的分析工具推薦 Eclipse Memory Analyzer(簡稱 MAT),該工具比 IBM 的HA(Heap Analyzer)工具更強(qiáng)大,更易使用。下面是工具的使用截圖:

該工具可以看到對(duì)象占用內(nèi)存的大小、對(duì)象的個(gè)數(shù)等信息,通過分析占用內(nèi)存比例最大的對(duì)象,可以初步判斷是哪個(gè)對(duì)象導(dǎo)致的內(nèi)存溢出,有關(guān) MAT 工具的具體使用這里不作詳細(xì)介紹。heapdump 分析的重點(diǎn)是找到占用內(nèi)存最大的“業(yè)務(wù)對(duì)象”,所謂業(yè)務(wù)對(duì)象,就是和應(yīng)用業(yè)務(wù)相關(guān)的對(duì)象,需要能靠到應(yīng)用程序上。例如上圖所示,雖然java.lang.String 比 DicRestrict 對(duì)象占用的內(nèi)存要多,但是我們做分析時(shí)應(yīng)該重點(diǎn)關(guān)注DicRestrict 對(duì)象,因?yàn)?String 對(duì)象是通用的業(yè)務(wù)無關(guān)對(duì)象,可能很多業(yè)務(wù)對(duì)象都會(huì)引用它。Heapdump 分析需要結(jié)合業(yè)務(wù)知識(shí),需要相當(dāng)?shù)拈_發(fā)和業(yè)務(wù)經(jīng)驗(yàn)。

3. 雙劍合并

Javacore 和 heapdump 的單獨(dú)分析,都只是看到了事情的一面,通過一定方法將二者有機(jī)的結(jié)合起來,問題基本就可以水落石出了。

責(zé)任編輯:趙寧寧 來源: 今日頭條
相關(guān)推薦

2018-05-24 10:15:18

服務(wù)器Session問題

2009-01-10 19:32:36

2018-12-12 08:40:11

服務(wù)器TomcatJava

2015-08-14 09:31:55

開源Python服務(wù)器

2009-02-27 14:25:00

Weblogic應(yīng)用服務(wù)器服務(wù)器管理

2012-02-02 10:24:08

JavaResin

2009-06-16 15:35:20

JBoss應(yīng)用服務(wù)器

2021-05-28 05:18:08

PHP語言roadrunnner

2012-02-23 10:02:08

Web服務(wù)器應(yīng)用服務(wù)器

2009-01-16 14:37:57

TomcatWeb服務(wù)器應(yīng)用服務(wù)器

2018-05-10 12:15:09

串口服務(wù)器故障

2018-02-07 10:08:02

應(yīng)用服務(wù)器網(wǎng)絡(luò)數(shù)據(jù)庫

2009-05-08 16:38:54

SpringHyperic服務(wù)器

2009-06-18 10:03:57

EquinoxOSGi應(yīng)用服務(wù)器

2014-08-08 16:35:37

應(yīng)用服務(wù)器

2012-03-23 09:32:48

應(yīng)用服務(wù)器

2009-06-16 12:02:37

JBoss IPv6

2018-03-20 14:24:10

Web服務(wù)器HTTP

2017-10-17 09:15:06

Web服務(wù)器區(qū)別
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 日韩综合在线播放 | 户外露出一区二区三区 | 国产一级免费在线观看 | 亚洲久久久 | 久久精点视频 | 色婷婷国产精品 | 久久精品成人一区 | 九九热精品视频 | 欧美在线国产精品 | 黄色一级片视频 | 国产电影精品久久 | 国产一区二区在线播放 | 亚洲人成一区二区三区性色 | 日本精品裸体写真集在线观看 | 超碰人人艹 | 亚洲精品亚洲人成人网 | 亚洲高清视频一区二区 | 成人二区 | 一区二区三区在线观看视频 | 日韩精品在线一区 | 久在线| 福利视频二区 | 国产精品色综合 | 久久国产福利 | 99热.com| 天天爽一爽| 亚洲欧美在线视频 | 粉嫩av在线 | 午夜在线 | 成人片免费看 | 一区二区三区在线免费 | 成人精品在线视频 | 日韩一区二区三区视频在线观看 | 国内精品久久精品 | 欧美日韩在线一区二区三区 | 国产成人精品久久二区二区 | 中文字幕亚洲无线 | 精品久久久久久亚洲精品 | 亚洲欧美日韩一区二区 | 夜夜爽99久久国产综合精品女不卡 | 国产真实精品久久二三区 |