Java死鎖問題的排查和解決方案-創(chuàng)新互聯(lián)

本篇內(nèi)容介紹了“Java死鎖問題的排查和解決方案”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

成都創(chuàng)新互聯(lián)專注于天橋企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站開發(fā),商城建設(shè)。天橋網(wǎng)站建設(shè)公司,為天橋等地區(qū)提供建站服務(wù)。全流程按需定制開發(fā),專業(yè)設(shè)計,全程項目跟蹤,成都創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)

1、為什么會出現(xiàn)死鎖?

要解決Java死鎖就必須追根究底,為什么會出現(xiàn)死鎖?其實從死鎖的定義就可以看出來,一方面是因為有兩個或者兩個以上進程,另一方面是因為有競爭資源。

2、怎么排查代碼中出現(xiàn)了死鎖?

(1)使用 jps + jstack

在windons命令窗口,使用jps -l

使用 jstack -l 12316

(2)使用jconsole

在window打開 JConsole,JConsole是一個圖形化的監(jiān)控工具!

在windons命令窗口 ,輸出JConsole

選擇到線程的tab上

(3)使用Java Visual VM

在window打開 jvisualvm,jvisualvm是一個圖形化的監(jiān)控工具!

在windons命令窗口 ,輸出 jvisualvm

依然是切換到線程這個TAB上,很明顯的就有提示!

3、如何避免死鎖?

上面說了死鎖出現(xiàn)的原因以及通過三種方式來檢測和排查死鎖,下面更重要的東西來了,就是如何避免死鎖,如果能夠讓寫出的代碼避免死鎖出現(xiàn)也就沒有上面這些排查的過程了。最好的是從源頭控制問題,而不是后期遇到問題在去填坑。
我看了阿里巴巴中最新的開發(fā)規(guī)約,里面有對避免死鎖的說明,具體如下:

死鎖的原因就是兩個線程試圖以不同的順序來獲得相同的鎖。所以,如果所有的線程以固定的順序來獲得鎖,那么在程序中就不會出現(xiàn)鎖順序死鎖的問題。

(1)動態(tài)的鎖順序死鎖

以一個經(jīng)典的轉(zhuǎn)賬案例來進行說明,我們知道轉(zhuǎn)賬就是將資金從一個賬戶轉(zhuǎn)入另一個賬戶。在開始轉(zhuǎn)賬之前,首先需要獲得這兩個賬戶對象得鎖,以確保通過原子方式來更新兩個賬戶中的余額,同時又不破壞一些不變形條件,例如 賬戶的余額不能為負數(shù)。

結(jié)論:由于我們無法控制transferMoney中的參數(shù)的順序,而這些參數(shù)順序取決于外部的輸入。所以兩個線程同時調(diào)用transferMoney,一個線程從X向Y轉(zhuǎn)賬,另一個線程從Y向X轉(zhuǎn)賬,那么就會發(fā)生互相等待鎖的情況,導(dǎo)致死鎖。

解決問題方案:定義鎖的順序,并且整個應(yīng)用中都按照這個順序來獲取鎖。

方案一:使用System.identityHashCode方法,該方法返回有Object.hashCode返回的值,此時可以通過某種任意方法來決定鎖的順序。但是在極少數(shù)情況下,兩個對象可能擁有相同的散列值,在這種情況下,通過給公共變量加鎖來實現(xiàn)給鎖制定順序。所以這種方法也是用最小的代價,換來了大的安全性。

方案二:在Account中包含一個唯一的,不可變的,值。比如說賬號等。通過對這個值對對象進行排序。

(2)在協(xié)作對象之間發(fā)生的死鎖

如果在持有鎖時調(diào)用某外部的方法,那么將出現(xiàn)活躍性問題。在這個外部方法中可能會獲取其他的鎖(這個可能產(chǎn)生死鎖),或阻塞時間過長,導(dǎo)致其他線程無法及時獲得當前持有的鎖。

場景如下:Taxi代表出租車對象,包含當前位置和目的地。Dispatcher代表車隊。當一個線程收到GPS更新事件時掉用setLocation,那么它首先更新出租車的位置,然后判斷它是否到達目的地。如果已經(jīng)到達,它會通知Dispatcher:它需要一個新的目的地。因為setLocation和notifyAvailable都是同步方法,因此掉用setLocation線程首先獲取taxi的鎖,然后在獲取Dispatcher的鎖。同樣,掉用getImage的線程首先獲取Dispatcher的鎖,再獲取每一個taxi的鎖,這兩個線程按照不同的順序來獲取鎖,因此可能導(dǎo)致死鎖。

解決方案:使用開放掉用。如果再調(diào)用某個方法時不需要持有鎖,那么這種調(diào)用就被稱為開放掉用。這種調(diào)用能有效的避免死鎖,并且易于分析線程安全。

“Java死鎖問題的排查和解決方案”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

名稱欄目:Java死鎖問題的排查和解決方案-創(chuàng)新互聯(lián)
網(wǎng)站路徑:http://muchs.cn/article14/dhepge.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計、網(wǎng)站收錄、網(wǎng)站改版、App設(shè)計、企業(yè)建站、云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)