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

因為內存溢出,我差點被優化

存儲 數據管理
在 Java? 中,那就是 Out Of Memory?,導致了不合理的 GC ,那么如何去定位這個內存溢出的呢?實際上如果是大公司,那么會有專業的運維人員去定位哪些程序導致了內存溢出,但是如果要是沒有專業的運維人員,那么你自己就得學會怎么去定位這個內存溢出了。

作為一個技術博主,了不起不是在創作就是在創作的路上(當然偶爾也會有點恰飯文~還指望大家多多支持),我們都知道,在寫代碼的過程中,業務邏輯很大程度上決定了你對業務的理解,但是解決問題,卻是你提升比較關鍵的地方,而了不起,卻差點因為這個內存溢出,把自己給干優化掉。

什么是內存溢出

百度百科是這么解釋的:

內存溢出(Out Of Memory?,簡稱OOM)是指應用系統中存在無法回收的內存或使用的內存過多,最終使得程序運行要用到的內存大于能提供的最大內存。此時程序就運行不了,系統會提示內存溢出,有時候會自動關閉軟件,重啟電腦或者軟件后釋放掉一部分內存又可以正常運行該軟件,而由系統配置、數據流、用戶代碼等原因而導致的內存溢出錯誤,即使用戶重新執行任務依然無法避免

其實很簡單,在 Java? 中,那就是 Out Of Memory?,導致了不合理的 GC ,那么如何去定位這個內存溢出的呢?實際上如果是大公司,那么會有專業的運維人員去定位哪些程序導致了內存溢出,但是如果要是沒有專業的運維人員,那么你自己就得學會怎么去定位這個內存溢出了。

如何定位內存溢出

一、定位占用CPU?最高的服務 1、先找到cpu占用比較高的進程:top -c? 進去后按Shift+P鍵

一般異常的進程cpu的占用會很高,記錄下這進程的PID

2、查看指定進程cpu?情況:top -cp PID

查看此進程占用cpu?最高的線程,記錄下線程的ppid?也可以將相關信息保存下來:top -Hp PID -o %CPU -n 1 >cpu.txt?到此,我們就找到的最占用cpu的進程以及相關線程。

3.如果你已經知道是你們的 Java? 程序導致了內存溢出,那么我們就得學會分析日志,一般在 Out Of Memory 的上方,我們都會有各種日志的輸出,來標志現在這個時間點,我們的程序執行了什么操作,導致了我們的這個內存溢出,分析到這里,就輪到看代碼了。

檢查的內容大致都有哪些地方呢?

在一個項目中,使用兩個數據庫連接,其中專用于發送短信的數據庫連接使用 DBCP? 連接池管理,用戶為不將短信發出,有意將數據庫連接用戶名改錯,使得日志中有許多數據庫連接異常的日志,一段時間后,就出現 OutOfMemory? 錯誤。經分析,這是由于 DBCP? 連接池 BUG? 引起的,數據庫連接不上后,沒有將連接釋放,最終使得D BCP? 報OutOfMemory 錯誤。

上面這是一個簡單的例子,比如還有其他的,代碼中是否有死循環或遞歸調用。是否有大循環重復產生新對象實體。檢查對數據庫查詢中,是否有一次獲得全部數據的查詢。一般來說,如果一次取十萬條記錄到內存,就可能引起內存溢出。這個問題比較隱蔽,在上線前,數據庫中數據較少,不容易出問題,上線后,數據庫中數據多了,一次查詢就有可能引起內存溢出。因此對于數據庫查詢盡量采用分頁的方式查詢。

檢查List、MAP?等集合對象是否有使用完后,未清除的問題。List、MAP?等集合對象會始終存有對對象的引用,使得這些對象不能被GC回收。

比如我們這次內存溢出,就是因為一個很簡答的導入功能,因為服務器給服務拆分的內存只有2G,而程序也沒有專門的去處理,實施導入數據的時候,直接把100w的空數據從Excel中直接導入了,結果,直接導致了內存溢出。那么我們應該怎么去處理這個呢?

其實我們的比較簡單,就是直接限定了文件的大小,因為Excel 雖然很大,但是有數據量的就那么幾百行,100w行,都是空行數據,還都識別了,所以處理方式就那么幾種,限制文件大小,限制讀取數據的時候不讀空行,因為畢竟內存大小是已經不允許我們做修改了,只能通過這個代碼業務層面來處理這個了。

如何解決內存溢出呢?

內存溢出的解決方案:

第一步,修改JVM?啟動參數,直接增加內存。(-Xms,-Xmx參數一定不要忘記加。)

第二步,檢查錯誤日志,查看OutOfMemory錯誤前是否有其它異?;蝈e誤。

第三步,對代碼進行走查和分析,找出可能發生內存溢出的位置。

重點排查以下幾點:

1.檢查對數據庫查詢中,是否有一次獲得全部數據的查詢。一般來說,如果一次取十萬條記錄到內存,就可能引起內存溢出。這個問題比較隱蔽,在上線前,數據庫中數據較少,不容易出問題,上線后,數據庫中數據多了,一次查詢就有可能引起內存溢出。因此對于數據庫查詢盡量采用分頁的方式查詢。

2.檢查代碼中是否有死循環或遞歸調用。

3.檢查是否有大循環重復產生新對象實體。

4.檢查List、MAP?等集合對象是否有使用完后,未清除的問題。List、MAP?等集合對象會始終存有對對象的引用,使得這些對象不能被GC回收。

第四步,使用內存查看工具動態查看內存使用情況

圖片

一般的,使用的工具有很多,MAT?(Memory Analyzer Tool) 這個工具是一個比較好用的分析內存的工具,還有 jmeter 這個壓力測試工具,可對特定接口進行壓測,分析tps、響應時間、CPU、內存等性能指標。

JConsole、JVisualVM? jdk 自帶可視化工具,可監控CPU、內存、線程等狀況。

責任編輯:武曉燕 來源: Java極客技術
相關推薦

2023-05-14 22:25:33

內存CPU

2020-07-01 09:07:52

SQL索引語句

2021-01-30 10:58:29

React應用程序開發

2020-08-07 07:54:08

代碼

2021-10-22 05:56:31

數據庫鎖表鎖定機制

2021-06-07 10:20:31

2019-12-16 08:47:04

Redis設計算法

2020-03-12 07:55:50

訪問量飆升DDoS

2020-07-13 08:40:48

同事代碼

2009-06-15 09:47:12

Java程序內存溢出

2020-05-29 08:14:49

代碼Try-Catch程序員

2020-11-18 09:56:46

Java開發代碼

2024-03-11 08:22:40

Java內存泄漏

2020-12-21 08:32:07

內存性能優化

2013-08-02 10:06:36

Android內存溢出

2018-05-23 11:43:59

數據庫

2019-05-30 06:37:38

網絡故障網絡協議網絡

2021-07-05 22:09:53

面試官CollectionsJDK7

2022-12-08 09:34:26

開發操作

2024-09-09 09:41:03

內存溢出golang開發者
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品欧美一区二区三区 | 日本激情视频中文字幕 | 久久国产精品免费视频 | 日韩视频中文字幕 | 欧美精品日韩精品国产精品 | 亚洲一区二区三区四区av | 天天干天天操天天看 | 亚洲国产精品久久久久 | 日韩欧美三级在线 | 久久精品二区亚洲w码 | 精品视频久久久久久 | 中文字幕视频在线观看 | 中文字幕第5页 | 久久精品亚洲精品国产欧美 | 日日骚网| 中文字幕在线观看一区 | 欧美成人影院在线 | 欧美精品99 | 精品国产一区久久 | 日韩电影免费观看中文字幕 | 日本一区二区在线视频 | 久草久 | 精品国产欧美一区二区 | aaa精品| 国产精品激情在线 | 国产亚洲网站 | 午夜影院在线播放 | 精品国产一区二区在线 | 午夜寂寞影院列表 | 久久伊人精品 | 精品麻豆剧传媒av国产九九九 | 99福利视频 | 日本免费一区二区三区四区 | 欧美精品一区久久 | 欧美日韩一区在线播放 | 亚洲一av | 少妇一级淫片免费播放 | 日本一区二区电影 | 超碰在线亚洲 | 成年无码av片在线 | 999久久久久久久久6666 |