使用Pinpoint作分布式鏈路跟蹤系統(tǒng)

【轉(zhuǎn)載請(qǐng)注明出處】:http://www.reibang.com/p/4129798aa4ae

Pinpoint是一個(gè)開源的 APM (Application Performance Management/應(yīng)用性能管理)工具,適用于用Java / PHP編寫的大型分布式系統(tǒng)。受Dapper的啟發(fā),Pinpoint提供了一種解決方案躲舌,通過跟蹤分布式應(yīng)用程序之間的事務(wù)捆姜,幫助分析系統(tǒng)的整體結(jié)構(gòu)以及它們中的組件如何相互連接赴恨。

Pinpoint的特性:

  • 一目了然地了解您的應(yīng)用程序拓?fù)?/li>
  • 實(shí)時(shí)監(jiān)控您的應(yīng)用程序
  • 獲得每個(gè)事務(wù)的代碼級(jí)可見性
  • 使用字節(jié)碼增強(qiáng)技術(shù)毫胜,添加新功能無需修改代碼
  • 對(duì)性能的影響最锌翊颉(資源使用量增加約3%)

Pinpoint系統(tǒng)架構(gòu)
Point是基于Google Dapper擂煞,使用Hbase作為存儲(chǔ),主要有三個(gè)組件:

  • pinpoint-collector:日志收集器模塊趴乡,主要手收集從agent端傳來的數(shù)據(jù)信息并存儲(chǔ)
  • pinpoint-web:控制臺(tái)視圖模塊对省,主要將collector的數(shù)據(jù)可視化的展示給用戶
  • pinpoint-agent:日志代理客戶端模塊,用于在客戶段進(jìn)行埋點(diǎn)來獲取到監(jiān)控信息

Pinpoint數(shù)據(jù)結(jié)構(gòu)
Pinpoint中晾捏,核心數(shù)據(jù)結(jié)構(gòu)由Span蒿涎,Trace和TraceID組成:

  • Span:跟蹤的基本單元,包含一個(gè)TraceId
  • Trace:多個(gè)Span集合惦辛,由關(guān)聯(lián)的RPC(Spans)組成劳秋,同一個(gè)trace共享一個(gè)相同的TransactionID,Trace通過SpanId和ParentSpanId整理繼承樹結(jié)構(gòu)。
  • TraceID:由 TransactionId, SpanId(64位長(zhǎng)度的整型), 和 ParentSpanId(64位長(zhǎng)度的整型) 組成的key的集合. TransactionId 指明消息ID胖齐,而SpanId 和 ParentSpanId 表示RPC的父-子關(guān)系
  • TransactionId:AgentIDs(建議使用hostname玻淑,服務(wù)器IP),JVM啟動(dòng)時(shí)間以及序列號(hào)組成

Pinpoint面板展示

  • ServerMap(服務(wù)地圖):通過可視化其組件的互連方式,了解任何分布式系統(tǒng)的拓?fù)洹螕艄?jié)點(diǎn)可顯示有關(guān)組件的詳細(xì)信息,例如其當(dāng)前狀態(tài)和事務(wù)計(jì)數(shù)呀伙。
  • Realtime Active Thread Chart(實(shí)時(shí)活動(dòng)線程圖):實(shí)時(shí)監(jiān)控應(yīng)用程序內(nèi)的活動(dòng)線程补履。
  • Request/Response Scatter Chart(響應(yīng)散點(diǎn)圖):可視化請(qǐng)求計(jì)數(shù)和響應(yīng)模式,以識(shí)別潛在的問題剿另◇锎福可以通過拖拽圖表來選擇事務(wù)以獲得更多詳細(xì)信息。
  • CallStack(調(diào)用棧):獲得分布式環(huán)境中每個(gè)事務(wù)的代碼級(jí)可視性雨女,在一個(gè)視圖中識(shí)別瓶頸和故障點(diǎn)麻汰。
  • Inspector(巡查):查看應(yīng)用其他細(xì)節(jié),如CPU使用率戚篙,內(nèi)存/垃圾回收五鲫,TPS和JVM參數(shù)。

Pinpoint安裝

依賴:

  • JDK
  • Tomcat
  • Zookeeper(安裝見文章
  • HBase(安裝見文章

先啟動(dòng)Zookeeper和HBase岔擂,下載HBase建表腳本并執(zhí)行

$HBASE_HOME/bin/hbase shell hbase-create.hbase
image.png

下載最新的發(fā)布版本https://github.com/naver/pinpoint/releases

image.png

配置pinpoint-collector

  1. 將pinpoint-collector-1.8.4.war到tomcat的webapps目錄中
  2. 修改pinpoint-collector.properties
     cluster.enable=true
     cluster.zookeeper.address=zk1,zk2,zk3   
     cluster.zookeeper.sessiontimeout=30000
     cluster.listen.ip=0.0.0.0
     cluster.listen.port=9997
    
  3. 編輯 hbase.properties
    hbase.client.host=zk1,zk2,zk3
    hbase.client.port=2181
    

配置pinpoint-web

  1. 將pinpoint-web-1.8.4.war解壓后放到tomcat的webapps目錄中的ROOT目錄
  2. 修改 pinpoint-web.properties配置信息
     cluster.zookeeper.address=zk1,zk2,zk3
     cluster.enable=true
     cluster.web.tcp.port=
     cluster.zookeeper.sessiontimeout=30000
     cluster.zookeeper.retry.interval=60000
     cluster.connect.address=127.0.0.1:9997
    
  3. 修改hbase.properties
     hbase.client.host=zk1,zk2,zk3
     hbase.client.port=2181
    

配置pinpoint-agent

  1. 修改文件pinpoint.config

  2. 啟動(dòng)服務(wù)時(shí)加如下VM參數(shù)

      -javaagent:$AGENT_PATH/pinpoint-bootstrap-1.8.4.jar
      -Dpinpoint.agentId=$AGENT_ID
      -Dpinpoint.applicationName=$APPLICATION_NAME
    

訪問pinpoint-web的tomcat端口即可看到面板


image.png

【轉(zhuǎn)載請(qǐng)注明出處】:http://www.reibang.com/p/4129798aa4ae

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末位喂,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子乱灵,更是在濱河造成了極大的恐慌塑崖,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件痛倚,死亡現(xiàn)場(chǎng)離奇詭異规婆,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門抒蚜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來掘鄙,“玉大人,你說我怎么就攤上這事嗡髓〔倌” “怎么了?”我有些...
    開封第一講書人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵饿这,是天一觀的道長(zhǎng)浊伙。 經(jīng)常有香客問我,道長(zhǎng)长捧,這世上最難降的妖魔是什么嚣鄙? 我笑而不...
    開封第一講書人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮串结,結(jié)果婚禮上哑子,老公的妹妹穿的比我還像新娘。我一直安慰自己奉芦,他們只是感情好赵抢,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開白布剧蹂。 她就那樣靜靜地躺著声功,像睡著了一般。 火紅的嫁衣襯著肌膚如雪宠叼。 梳的紋絲不亂的頭發(fā)上先巴,一...
    開封第一講書人閱讀 49,031評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音冒冬,去河邊找鬼伸蚯。 笑死,一個(gè)胖子當(dāng)著我的面吹牛简烤,可吹牛的內(nèi)容都是我干的剂邮。 我是一名探鬼主播,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼横侦,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼挥萌!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起枉侧,我...
    開封第一講書人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤引瀑,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后榨馁,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體憨栽,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了屑柔。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片屡萤。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖锯蛀,靈堂內(nèi)的尸體忽然破棺而出灭衷,到底是詐尸還是另有隱情,我是刑警寧澤旁涤,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布翔曲,位于F島的核電站,受9級(jí)特大地震影響劈愚,放射性物質(zhì)發(fā)生泄漏瞳遍。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一菌羽、第九天 我趴在偏房一處隱蔽的房頂上張望掠械。 院中可真熱鬧,春花似錦注祖、人聲如沸猾蒂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽肚菠。三九已至,卻和暖如春罩缴,著一層夾襖步出監(jiān)牢的瞬間蚊逢,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來泰國打工箫章, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留烙荷,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓檬寂,卻偏偏與公主長(zhǎng)得像终抽,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子桶至,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345