Pinpoint源碼解析(四)

本節(jié)主要分析pinpoint-collect的源碼。

1、項目結構

采用Spring MVC構架,所以入口在web.xml,web中主要引入了applicationContext-collector.xml和servlet-context.xml文件。

servlet-context.xml中主要定義了spring中相關內容,包括掃描control類,jsp視圖,以及攔截器等。

applicationContext-collector.xml是collector的重點,包括加載屬性文件,hbase配置文件,以及相關的一些bean。

這些bean中非常重要的一個bean就是serverAcceptor,主要作用是定義管理Thrift傳輸?shù)姆斩耍?/p>

他是由類PinpointServerAcceptor定義的,PinpointServerAcceptor的構造函數(shù)中主要是

ServerBootstrap bootstrap = createBootStrap(1,WORKER_COUNT);

setOptions(bootstrap);

addPipeline(bootstrap);

這三句,createBootStrap中定義了boss和worker線程池,addPipeline是將handler添加到管道中,這個handler 主要是由nettyChannelHandler定義的,nettyChannelHandler是由

PinpointServerChannelHandler nettyChannelHandler =new PinpointServerChannelHandler();

初始化的,在PinpointServerChannelHandler類中,定義了channelConnected,channelDisconnected,channelClosed和messageReceived方法,
messageReceived方法根據packetType來處理包,有的存入Hbase數(shù)據庫,有的產生response返回Agent。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,506評論 19 139
  • Spring Boot 參考指南 介紹 轉載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 47,253評論 6 342
  • 1. Java基礎部分 基礎部分的順序:基本語法,類相關的語法,內部類的語法,繼承相關的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,626評論 18 399
  • 一. Java基礎部分.................................................
    wy_sure閱讀 3,995評論 0 11

友情鏈接更多精彩內容