【分布式日志系統(tǒng)】springboot+zipkin+dubbo實(shí)現(xiàn)鏈路跟蹤(上)

但行好事继榆,莫問(wèn)前程巾表。互聯(lián)網(wǎng)的前程如何網(wǎng)絡(luò)上各種大神從十萬(wàn)八千個(gè)緯度已經(jīng)分析過(guò)了略吨,但是作為技術(shù)人員集币,我們需要的是練好內(nèi)功,厚積薄發(fā)翠忠。

一鞠苟、為什么要用鏈路跟蹤

微服務(wù)大行其道的今天,如果做的是一個(gè)單體應(yīng)用秽之,甚至三個(gè)以內(nèi)的服務(wù)当娱,對(duì)于問(wèn)題的排查上,使用原始的登錄服務(wù)器考榨,一個(gè)一個(gè)日志文件對(duì)比當(dāng)然可行跨细,并且一般結(jié)合用戶的資金情況,大概率是要使用這種方案的河质。
然后當(dāng)有了五個(gè)冀惭、十個(gè)申鱼、五十個(gè)服務(wù),每個(gè)服務(wù)有10個(gè)節(jié)點(diǎn)的集群時(shí)候云头,怎么破?一臺(tái)一臺(tái)去查淫半?當(dāng)然不現(xiàn)實(shí)溃槐。這時(shí)候就需要一個(gè)分布式日志系統(tǒng)來(lái)幫忙收集、清洗科吭、分析日志昏滴,并提供良好的查詢方式。
日志可以查詢了对人,那么所有的都集中到一起谣殊,微服務(wù)又是網(wǎng)格狀調(diào)用關(guān)系,怎么知道哪個(gè)服務(wù)的上下游關(guān)系呢牺弄?知道了上下游之后又怎么對(duì)應(yīng)到某一次請(qǐng)求上呢姻几?顧名思義:鏈路跟蹤解決某一次請(qǐng)求從頭到尾(經(jīng)歷N個(gè)微服務(wù)調(diào)用)的整個(gè)鏈路狀況,包括各服務(wù)上時(shí)間消耗势告、調(diào)用順序等蛇捌。

二、方案選擇

基于以上需求咱台,日志管理系統(tǒng)當(dāng)前有多種解決方案:阿里系络拌、騰訊系。當(dāng)然對(duì)于更多的應(yīng)該是開(kāi)源系回溺,開(kāi)源環(huán)境中當(dāng)前最流行的莫過(guò)于ELK架構(gòu)春贸。但是對(duì)于這個(gè)系列文章,只針對(duì)日志系統(tǒng)中鏈路跟蹤這一個(gè)小的點(diǎn)進(jìn)行討論遗遵。網(wǎng)上有多種方案萍恕,zipkin+sleuth、skywalking瓮恭、CAT雄坪、Pinpoint等,各有優(yōu)缺點(diǎn)屯蹦,大家可以參考下圖自行比較選擇维哈。


對(duì)比.png

由于我使用springboot+spring cloud,因此決定走全家桶的模式登澜,選擇zipkin+sleuth阔挠,理論上應(yīng)該會(huì)支持的更好,然鵝······
現(xiàn)實(shí)很骨感脑蠕,因?yàn)槲业腞PC框架選擇了dubbo购撼,而阿里早已將dubbo交給apache跪削,包路徑已從com.alibaba.dubbo 2.6.6 升級(jí)為org.apache.dubbo 2.7.12,而sleuth的進(jìn)展比較緩慢迂求,如今仍不支持dubbo2.7+碾盐,因此暫時(shí)舍棄sleuth,只集成zipkin來(lái)進(jìn)行手動(dòng)跟蹤揩局。

三毫玖、原理

通過(guò)攔截器生成(或放入)traceId,spanId,parentId,其中traceId作為整個(gè)請(qǐng)求過(guò)程的跟蹤依據(jù)凌盯,貫穿整個(gè)請(qǐng)求過(guò)程付枫;spanId為某個(gè)服務(wù)唯一,作為下游服務(wù)的parentId驰怎,用于構(gòu)建上下游調(diào)用關(guān)系阐滩。

四、預(yù)期效果

構(gòu)建web應(yīng)用A县忌,dubbo服務(wù)B掂榔,dubbo服務(wù)C。
A作為請(qǐng)求入口芹枷,調(diào)用服務(wù)B衅疙,服務(wù)B作為消費(fèi)者,調(diào)用服務(wù)C鸳慈。
希望可以通過(guò)traceId,spanId,parentId來(lái)分析整個(gè)調(diào)用過(guò)程饱溢。
希望得到如下結(jié)構(gòu),便可根據(jù)traceId=1獲取整個(gè)請(qǐng)求過(guò)程由A走芋、B绩郎、C組成,且調(diào)用關(guān)系為A-->B-->C:

A: traceId = 1,spanId = 1,parentId='';
B: traceId = 1,spanId = 2, parentId = 1;
C: traceId = 1,spanId = 3, parentId = 2;
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末翁逞,一起剝皮案震驚了整個(gè)濱河市肋杖,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌挖函,老刑警劉巖状植,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異怨喘,居然都是意外死亡津畸,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門必怜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)肉拓,“玉大人,你說(shuō)我怎么就攤上這事梳庆∨荆” “怎么了卑惜?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)驻售。 經(jīng)常有香客問(wèn)我露久,道長(zhǎng),這世上最難降的妖魔是什么欺栗? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任抱环,我火速辦了婚禮,結(jié)果婚禮上纸巷,老公的妹妹穿的比我還像新娘。我一直安慰自己眶痰,他們只是感情好瘤旨,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著竖伯,像睡著了一般存哲。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上七婴,一...
    開(kāi)封第一講書(shū)人閱讀 49,185評(píng)論 1 284
  • 那天祟偷,我揣著相機(jī)與錄音,去河邊找鬼打厘。 笑死修肠,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的户盯。 我是一名探鬼主播嵌施,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼莽鸭!你這毒婦竟也來(lái)了吗伤?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤硫眨,失蹤者是張志新(化名)和其女友劉穎足淆,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體礁阁,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡巧号,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了氮兵。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片裂逐。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖泣栈,靈堂內(nèi)的尸體忽然破棺而出卜高,到底是詐尸還是另有隱情弥姻,我是刑警寧澤,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布掺涛,位于F島的核電站庭敦,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏薪缆。R本人自食惡果不足惜秧廉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望拣帽。 院中可真熱鬧疼电,春花似錦、人聲如沸减拭。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)拧粪。三九已至修陡,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間可霎,已是汗流浹背魄鸦。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留癣朗,地道東北人拾因。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像旷余,于是被迫代替她去往敵國(guó)和親盾致。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344