windows java.exe內(nèi)存暴漲解決、idea跑java tomcat內(nèi)存無(wú)限增長(zhǎng)
最近突然遇到個(gè)問題:用 idea 跑 Tomcat 服務(wù),不到30分鐘 內(nèi)存就吃完了。用任務(wù)管理器查看,發(fā)現(xiàn) java.exe占了10G內(nèi)存!!
查了各種方法
一、 idea Tomcat 配置沒用!!!
二、idea idea64.exe.vmoptions安裝目錄下的 bin 下的 idea64.exe.vmoptions 配置,還是 C:UsersAdministrator.IntelliJIdea2019.1config 下的 idea64.exe.vmoptions 配置 改成如下
也沒用!!
三、jvisualvm.exe 檢查然后打開 jdk/bin的 jvisualvm.exe 監(jiān)控發(fā)現(xiàn)里面的 堆,棧等內(nèi)存空間也是正常的
著實(shí)郁悶,感覺java線程的最大內(nèi)存完全不由這些配置控制。
四、線程狀態(tài)檢查后來根據(jù)這 篇文章做了排查,發(fā)現(xiàn)也不是程序引發(fā)的問題。
五、解決最后是解決了,方法是
打開控制臺(tái),執(zhí)行【 java -Xmx2048m -XX:MaxPermSize=1024m -version】
如此內(nèi)存是控制住了。
【猜想】:如果沒有給JVM 設(shè)置內(nèi)存上限,他會(huì)一直跟操作系統(tǒng)申請(qǐng)內(nèi)存。前面幾步都沒能設(shè)置到位,或者說設(shè)置不成功。
補(bǔ)充:java Thread卡死 項(xiàng)目?jī)?nèi)存一直增長(zhǎng)
1.今天項(xiàng)目中出現(xiàn)了一個(gè)問題,虛擬內(nèi)存、物理內(nèi)存一直持續(xù)增長(zhǎng),項(xiàng)目需要每隔一小時(shí)重啟一次。很是蛋疼。。怎么辦呢? 很捉急啊。以下是解決方案,有相同問題的小伙伴,可以參考參考。
首先查看內(nèi)存
1.top查看pid 11112 (我的進(jìn)程號(hào))
2.top -H -p 11112查看線程占用比例 得到線程11140 比較高
3. printf %x 11140轉(zhuǎn)換為16進(jìn)制 2b84
4.jstack 11112 | grep 2b84 -A 30jdk的bin目錄下查看代碼
報(bào)錯(cuò):
'pool-4392-thread-1' prio=10 tid=0x00007fa4321be800 nid=0x2786 waiting on condition [0x00007fa2dc013000]java.lang.Thread.State: WAITING (parking)at sun.misc.Unsafe.park(Native Method)- parking to wait for <0x00000000fc0c7ba0> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)at java.util.concurrent.locks.LockSupport.park(LockSupport.java:186)at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2043)at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:442)at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1068)at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)at java.lang.Thread.run(Thread.java:745)
出現(xiàn)以上問題是因?yàn)榫€程卡死問題。經(jīng)過查看代碼,是由于在循環(huán)中Thread.sleep()線程了,導(dǎo)致卡死。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. python實(shí)現(xiàn)讀取類別頻數(shù)數(shù)據(jù)畫水平條形圖案例2. python中PyQuery庫(kù)用法分享3. python操作數(shù)據(jù)庫(kù)獲取結(jié)果之fetchone和fetchall的區(qū)別說明4. ASP.NET MVC前臺(tái)動(dòng)態(tài)添加文本框并在后臺(tái)使用FormCollection接收值5. CSS3實(shí)現(xiàn)動(dòng)態(tài)翻牌效果 仿百度貼吧3D翻牌一次動(dòng)畫特效6. Python數(shù)據(jù)分析之繪圖和可視化詳解7. Python編寫nmap掃描工具8. JavaScript實(shí)現(xiàn)組件化和模塊化方法詳解9. .NET6打包部署到Windows Service的全過程10. ASP動(dòng)態(tài)網(wǎng)頁(yè)制作技術(shù)經(jīng)驗(yàn)分享
