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

原文鏈接:http://blog.csdn.net/raintungli/article/details/7023092
【系列文章】















 
 
 


 
 
 
 