日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > > 架構師社區(qū)
[導讀]在微服務架構中,一次請求往往涉及到多個模塊,多個中間件,多臺機器的相互協(xié)作才能完成。這一系列調用請求中,有些是串行的,有些是并行的,那么如何確定這個請求背后調用了哪些服務,哪些模塊,哪些節(jié)點及調用的先后順序?如何定位每個模塊的性能問題?本文將為你揭曉答案。


前言

在微服務架構中,一次請求往往涉及到多個模塊,多個中間件,多臺機器的相互協(xié)作才能完成。這一系列調用請求中,有些是串行的,有些是并行的,那么如何確定這個請求背后調用了哪些服務,哪些模塊,哪些節(jié)點及調用的先后順序?如何定位每個模塊的性能問題?本文將為你揭曉答案。


微服務架構

這是一個稍微復雜的例子

微服務追蹤系統(tǒng),你絕對想不到!

如果有用戶反饋某個頁面很慢,我們知道這個頁面的請求調用鏈是 A -----> ?C -----> ?B -----> ?D,此時如何定位可能是哪個模塊引起的問題呢?


更進一步,如果每個服務 Service A,B,C,D 都部署在好幾臺機器上。怎么知道某個請求調用了服務的具體哪臺機器呢?

微服務追蹤系統(tǒng),你絕對想不到!

可以明顯看到,由于無法準確定位每個請求經(jīng)過的確切路徑,在微服務這種架構下有以下幾個痛點:

1. 排查問題難度大,周期長

2. 特定場景難復現(xiàn)

3.系統(tǒng)性能瓶頸分析較難

有沒有一種辦法可以準確地產(chǎn)生完整的調用鏈,并且用可視化的方式呈現(xiàn)出來呢?

這就需要一個分布式調用鏈追蹤系統(tǒng)。

微服務追蹤系統(tǒng),你絕對想不到!


分布式調用鏈追蹤系統(tǒng):設計

想想看,如果要我們自己實現(xiàn)一個這樣的分布式追蹤系統(tǒng),該怎么去設計?

首先,我們必須得區(qū)分每個調用鏈(起個時髦的名稱叫 Trace),得給它分配一個全局唯一的 ID (稱為 TraceID),并且在調用鏈上的每次調用都帶上這個 ID,這樣每個子調用都被關聯(lián)起來了。

微服務追蹤系統(tǒng),你絕對想不到!

其次,我們得記錄所有調用的先后次序和父子關系。

假設有以上這樣的調用鏈,如果我們只記錄了這四個調用:

A---->B

B---->C

A---->D

D---->E

D---->F

雖然我們知道它屬于一個調用(TraceID 相同),還是無法畫出完整的調用拓撲圖。

所以必須得記錄父子關系:

A---->B 是 B---->C 的父調用

A---->D 是 D---->E 的父調用

A---->D 還是 D---->F 的父調用

如何記錄呢?需要給每個調用分配一個ID (稱為 SpanID),并且把這個 ID 傳遞給子調用, 子調用根據(jù) Parent Span ID 生成自己的 SpanID:

微服務追蹤系統(tǒng),你絕對想不到!

用表格展示是這樣:

微服務追蹤系統(tǒng),你絕對想不到!

這樣根據(jù) id 間的關系就很容易據(jù)此畫出調用鏈了(即可視化視圖)


魔法師Agent

前面說得挺容易,但是在分布式的環(huán)境下,如何才能正確地生成 TraceID, ParentSpanID, SpanID 呢?

微服務是來實現(xiàn)業(yè)務的,肯定不能來干這個監(jiān)控和跟蹤的活兒,那樣對微服務的侵入性就太強了。

所以必須得有一個獨立的組件,在不干擾微服務的情況下,監(jiān)控微服務之間的調用,把這些 ID 生成, 這個獨立的組件就是 Agent。

Agent 要想施展魔法,需要安裝在每個服務所在的機器上:

微服務追蹤系統(tǒng),你絕對想不到!

這個魔法師遵循的規(guī)則也非常簡單,以上圖中服務 A 上的 Agent 為例:

1. 當 Agent 監(jiān)控到有人在調用服務 A,但是沒有 ParentSpanID, 它就知道,這是一次全新的調用,應該創(chuàng)建新的 TraceID。

2. 當Agent監(jiān)控到 A 調用了 B 時, 它就可以生成 SpanID = 1,并且把這個 ID 當作 ParentSpanID 傳遞給 B。這樣當 B 調用 C 的時候, B 的 Agent 就能生成此次調用的 SpanID 為 1.1

3. 當 Agent 監(jiān)控到 A 調用 D 的時候,可以生成 SpanID = 2, 并且把這個 ID 當作 ParentSpanID 傳遞給 D

D 在調用 E 和 F 的時候,就能分別生成 SpanID 2.1 和 2.2

你也許注意到了一個問題:微服務都是跨進程調用的,怎么可能把 TraceID , ParentSpanID 在服務之間傳來傳去呢?

這就需要 Agent 來施展“魔法”了,Agent 需要理解微服務之間的傳輸協(xié)議,然后把 TraceID,ParentSpanID 悄悄地“藏”到某個地方,傳遞給下一個服務。

例如 HTTP 協(xié)議中定義了 Header 與 Body,Header 一般放請求的長度,請求 IP等非業(yè)務的信息。業(yè)務數(shù)據(jù)一般放在 Body 中。于是 Agent 就可以把 TraceID,ParentSpanID 悄悄地“藏到”? Header 中,這樣既不會對 Body 中的業(yè)務數(shù)據(jù)造成影響,又可以把跟蹤所需的數(shù)據(jù)傳遞給下一個服務了。

你的腦海中可能已經(jīng)想到 Agent 的實現(xiàn)原理了,這個 Agent 可以這么來實現(xiàn):

指定微服務中的“RPC 調用的公用程序”(例如 Dubbo 中的 MonitorFilter.invoke方法), 然后在運行時,通過動態(tài)修改字節(jié)碼的方式來增強它:

微服務追蹤系統(tǒng),你絕對想不到!

當服務 A 調用服務 B 時, Agent 就可以做點兒手腳,修改 header 了:

微服務追蹤系統(tǒng),你絕對想不到!

數(shù)據(jù)收集

Agent 雖然監(jiān)控、生成了足夠多的數(shù)據(jù),但是單個 Agent 無法獲得全局視圖,我們需要一個全局的收集器來把 Agent 的數(shù)據(jù)收集上來,這樣才能生成全局的調用鏈。

微服務追蹤系統(tǒng),你絕對想不到!

數(shù)據(jù)收集器獲得了全局的數(shù)據(jù)以后,就可以畫出漂亮的調用鏈的圖了,例如這個:

微服務追蹤系統(tǒng),你絕對想不到!

小結

經(jīng)過一番探索,一個分布式調用鏈系統(tǒng)的核心組件和實現(xiàn)原理浮出水面,當然,其中還有很多細節(jié)需要處理,例如采樣的頻率,全局唯一 ID 的生成算法,UI界面等等。市面上有不少開源的分布式跟蹤系統(tǒng),如 SkyWalking、Zipkin、Pinpoint 等等,感興趣的可以繼續(xù)深入研究。


免責聲明:本文內(nèi)容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

特朗普集團近日取消了其新推出的T1智能手機“將在美國制造”的宣傳標語,此舉源于外界對這款手機能否以當前定價在美國本土生產(chǎn)的質疑。

關鍵字: 特朗普 蘋果 AI

美國總統(tǒng)特朗普在公開場合表示,他已要求蘋果公司CEO蒂姆·庫克停止在印度建廠,矛頭直指該公司生產(chǎn)多元化的計劃。

關鍵字: 特朗普 蘋果 AI

4月10日消息,據(jù)媒體報道,美國總統(tǒng)特朗普宣布,美國對部分貿(mào)易伙伴暫停90天執(zhí)行新關稅政策,同時對中國的關稅提高到125%,該消息公布后蘋果股價飆升了15%。這次反彈使蘋果市值增加了4000多億美元,目前蘋果市值接近3萬...

關鍵字: 特朗普 AI 人工智能 特斯拉

3月25日消息,據(jù)報道,當?shù)貢r間3月20日,美國總統(tǒng)特朗普在社交媒體平臺“真實社交”上發(fā)文寫道:“那些被抓到破壞特斯拉的人,將有很大可能被判入獄長達20年,這包括資助(破壞特斯拉汽車)者,我們正在尋找你?!?/p> 關鍵字: 特朗普 AI 人工智能 特斯拉

1月22日消息,剛剛,新任美國總統(tǒng)特朗普放出重磅消息,將全力支持美國AI發(fā)展。

關鍵字: 特朗普 AI 人工智能

特朗普先生有兩件事一定會載入史冊,一個是筑墻,一個是挖坑。在美墨邊境筑墻的口號確保邊境安全,降低因非法移民引起的犯罪率過高問題;在中美科技產(chǎn)業(yè)之間挖坑的口號也是安全,美國企業(yè)不得使用對美國國家安全構成威脅的電信設備,總統(tǒng)...

關鍵字: 特朗普 孤立主義 科技產(chǎn)業(yè)

據(jù)路透社1月17日消息顯示,知情人士透露,特朗普已通知英特爾、鎧俠在內(nèi)的幾家華為供應商,將要撤銷其對華為的出貨的部分許可證,同時將拒絕其他數(shù)十個向華為供貨的申請。據(jù)透露,共有4家公司的8份許可被撤銷。另外,相關公司收到撤...

關鍵字: 華為 芯片 特朗普

曾在2018年時被美國總統(tǒng)特朗普稱作“世界第八奇跡”的富士康集團在美國威斯康星州投資建設的LCD顯示屏工廠項目,如今卻因為富士康將項目大幅縮水并拒絕簽訂新的合同而陷入了僵局。這也導致富士康無法從當?shù)卣抢铽@得約40億美...

關鍵字: 特朗普 富士康

今年5月,因自己發(fā)布的推文被貼上“無確鑿依據(jù)”標簽而與推特發(fā)生激烈爭執(zhí)后,美國總統(tǒng)特朗普簽署了一項行政令,下令要求重審《通信規(guī)范法》第230條。

關鍵字: 谷歌 facebook 特朗普

眾所周知,寄往白宮的所有郵件在到達白宮之前都會在他地進行分類和篩選。9月19日,根據(jù)美國相關執(zhí)法官員的通報,本周早些時候,執(zhí)法人員截獲了一個寄給特朗普總統(tǒng)的包裹,該包裹內(nèi)包含蓖麻毒蛋白。

關鍵字: 美國 白宮 特朗普
關閉