新聞中心
鏈路追蹤概念
什么是鏈路追蹤,用來解決什么問題

成都創(chuàng)新互聯(lián)公司10多年成都定制網(wǎng)站服務(wù);為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計及高端網(wǎng)站定制服務(wù),成都定制網(wǎng)站及推廣,對成都柴油發(fā)電機等多個方面擁有豐富的網(wǎng)站運維經(jīng)驗的網(wǎng)站建設(shè)公司。
- 用戶行為鏈路,如:瀏覽頁面,觀看視頻,購買商品,收藏,評論等等行為
- 服務(wù)流程鏈路,快速定位異常:用戶發(fā)起退貨,遲遲沒收到退回的商品,哪個鏈條出了問題?
- 大數(shù)據(jù)ai畫像,一個鏈條下非業(yè)務(wù)的動態(tài)行為數(shù)據(jù),才是最貼近用戶的素材
服務(wù)追蹤的基礎(chǔ)出發(fā)點—記錄足跡
- 入口處生成鏈路標識traceid
- 傳遞traceid參數(shù)給下層業(yè)務(wù)方法
- 各方法內(nèi)部記錄訪問信息
使用TreadLocal來傳參數(shù)
ThreadLocal,很多地方叫做線程本地變量,也有些地方叫做線程本地存儲,其實意思差不多。可能很多朋友都知道ThreadLocal為變量在每個線程中都創(chuàng)建了一個副本,那么每個線程可以訪問自己內(nèi)部的副本變量。
思考:使用TreadLocal來傳參數(shù)
如何讓traceid的傳遞不侵入業(yè)務(wù)?
- 盡量少侵入業(yè)務(wù)代碼
- 不需要開發(fā)人員來維護
MDC -----Mapped Diagnostic Context
- 與當前線程綁定 ---- Threadlocal
- 放數(shù)據(jù)--- MDC.put(traceid,aaa)
- 取數(shù)據(jù)--- MDC.get(traceid)
- 日志格式----%X{traceId}
分布式調(diào)用來了?
看看dubbo里的rpc調(diào)用
Dubbo使用filter
Dubbo高階---spi擴展機制
完美,優(yōu)雅地解決掉了rpc的透傳問題!
微服務(wù)
軟件架構(gòu)是一個包含各種組織的系統(tǒng)組織,這些組件包括 Web服務(wù)器, 應(yīng)用服務(wù)器, 數(shù)據(jù)庫,存儲, 通訊層), 它們彼此或和環(huán)境存在關(guān)系。系統(tǒng)架構(gòu)的目標是解決利益相關(guān)者的關(guān)注點
微服務(wù)是指開發(fā)一個單個小型的但有業(yè)務(wù)功能的服務(wù),每個服務(wù)都有自己的處理和輕量通訊機制,可以部署在單個或多個服務(wù)器上。微服務(wù)也指一種種松耦合的、有一定的有界上下文的面向服務(wù)架構(gòu)。也就是說,如果每個服務(wù)都要同時修改,那么它們就不是微服務(wù),因為它們緊耦合在一起;如果你需要掌握一個服務(wù)太多的上下文場景使用條件,那么它就是一個有上下文邊界的服務(wù),這個定義來自DDD領(lǐng)域驅(qū)動設(shè)計
相對于單體架構(gòu)和SOA,它的主要特點是組件化、松耦合、自治、去中心化,體現(xiàn)在以下幾個方面
- 一組小的服務(wù)
服務(wù)粒度要小,而每個服務(wù)是針對一個單一職責的業(yè)務(wù)能力的封裝,專注做好一件事情。
- 獨立部署運行和擴展
每個服務(wù)能夠獨立被部署并運行在一個進程內(nèi)。這種運行和部署方式能夠賦予系統(tǒng)靈活的代碼組織方式和發(fā)布節(jié)奏,使得快速交付和應(yīng)對變化成為可能。
- 獨立開發(fā)和演化
技術(shù)選型靈活,不受遺留系統(tǒng)技術(shù)約束。合適的業(yè)務(wù)問題選擇合適的技術(shù)可以獨立演化。服務(wù)與服務(wù)之間采取與語言無關(guān)的API進行集成。相對單體架構(gòu),微服務(wù)架構(gòu)是更面向業(yè)務(wù)創(chuàng)新的一種架構(gòu)模式。
- 獨立團隊和自治
團隊對服務(wù)的整個生命周期負責,工作在獨立的上下文中,自己決策自己治理,而不需要統(tǒng)一的指揮中心。團隊和團隊之間通過松散的社區(qū)部落進行銜接。
名稱欄目:實用架構(gòu)技術(shù),阿里P7架構(gòu)師教你如何設(shè)計解決方案
網(wǎng)站路徑:http://m.jiaoqi3.com/article/djoehee.html


咨詢
建站咨詢
