Java開源工具在linux上的源碼分析(一):跟蹤方式
在我們常用的Jstack, Jmap 用于分析java虛擬機的狀態(tài)的工具,通過起另一個虛擬機通過運行sun.tools包下的java文件,去跟蹤另一個虛擬機的狀態(tài)。
如果讓你設(shè)計一個跟蹤另一個進程的方法,你也通常會考慮這幾種常用的方式。
***種,就是通知被跟蹤的進程,讓進程執(zhí)行相應(yīng)的消息,同時對該消息做出反應(yīng)。
第二種,就是通過內(nèi)核的調(diào)用,直接能夠訪問進程的內(nèi)存,堆棧情況,通過分析被跟蹤的進程的內(nèi)存結(jié)構(gòu),從而知道當前被跟蹤的進程的狀態(tài)。
***種方式
優(yōu)勢:
對調(diào)用者和被調(diào)用者只要達成簡單的通訊協(xié)議,調(diào)用者無需知道被調(diào)用者的邏輯,結(jié)構(gòu),只需要簡單的發(fā)送命令的方式,被調(diào)用者能夠接受到命令,并且對該命令進行回應(yīng)就可以。
缺點:
如果被調(diào)用者當時的狀態(tài)本來就不正常,或者繁忙,沒辦法對該命令做出響應(yīng),那這個跟蹤進程往往是在規(guī)定的等待時間里,無法返回正確的需要的信息。其次被調(diào)用者在分析的過程中,有可能需要暫停進程中的其他的線程,而對被跟蹤的進程有一定的影響。
第二種方式
優(yōu)勢:
通過內(nèi)核的支持,訪問被跟蹤的內(nèi)存,并作出快照,后臺分析,很少影響被跟蹤的進程。
缺點:
這種方式需要對被跟蹤程的內(nèi)存分配和使用非常的了解,無法解耦,而本身系統(tǒng)內(nèi)核調(diào)用也會出問題。
Java工具類中也是大致實現(xiàn)了這2中方式,工具中會先選擇***種方式,如果發(fā)現(xiàn)***種方式不能成功,將會建議使用-F參數(shù),也就是第二種方式。
我們先講***種方式。
既然是需要向被跟蹤進程發(fā)出命令,在linux中可以選擇多種方式進行進程中通訊 共享內(nèi)存,文件之類,其中創(chuàng)建socket的文件實現(xiàn)通訊是比較簡單的方法。
下面是整個的流程圖:
原文鏈接:http://blog.csdn.net/raintungli/article/details/7023092
【系列文章】