java內(nèi)存溢出排查 java線程死鎖和內(nèi)存溢出,該怎么解決?
java線程死鎖和內(nèi)存溢出,該怎么解決?java線程死鎖或者線程數(shù)過高的:1、獲取java的進程IDps -ef|grep java 2、導(dǎo)出線程堆棧(其中32494換為上一個步驟查詢到的進程ID)j
java線程死鎖和內(nèi)存溢出,該怎么解決?
java線程死鎖或者線程數(shù)過高的:
1、獲取java的進程ID
ps -ef|grep java
2、導(dǎo)出線程堆棧(其中32494換為上一個步驟查詢到的進程ID)
jstack -l 32494 >> /usr/local/Client/log20180116.log
3、將上一個步驟生成導(dǎo)出.log 文件拷貝到本機,然后用記事本打開,檢查哪個線程有大量的重復(fù),之后再結(jié)合業(yè)務(wù)進行排除。(比如如果60%都是其中某個類的某個方法引起的堆棧,則很有可能是這個方法阻塞了)
java中while(true)死循環(huán)會造成JVM內(nèi)存溢出嗎?
1、把局部變量定義在死循環(huán)里面會造成棧溢出,諸如下面的定義:
while(true){
int x=1;
int arr[]= new int[10];
}
因為??臻g存儲局部變量、參數(shù)等對象,棧是有默認深度的,我記得是128M(記憶問題,錯了請指出)。
2、把對象定義在起循環(huán)里面會產(chǎn)生堆內(nèi)存溢出,諸如下列定義:
while(true){
Person p = new Person()
}
對象的生成是占時間和空間的,因為你的內(nèi)存空間有限,早晚會產(chǎn)生堆空間內(nèi)存溢出。
所以大家寫代碼要養(yǎng)成良好習(xí)慣,不在特殊情況下,不要把局部變量和對象定義在循環(huán)里面。