隨着互聯網架構的擴張,分佈式系統變得日趨複雜,愈來愈多的組件開始走向分佈式化,如微服務、消息收發、分佈式數據庫、分佈式緩存、分佈式對象存儲、跨域調用,這些組件共同構成了繁雜的分佈式網絡。數據庫
在一次800多人的開發者調研中,當回答「現階段構建一個高可用的分佈式系統,您遇到的三個最大的難題是什麼?」時,57%的開發者選擇了全鏈路追蹤。跨域
6月12日,阿里雲發佈了鏈路追蹤服務 Tracing Analysis,提供分佈式系統的全鏈路追蹤能力,幫助客戶快速發現和定位分佈式系統下的各種性能瓶頸,成本僅自建鏈路追蹤系統的1/5甚至更少。緩存
微服務架構下的分佈式應用架構雖然知足了應用橫向擴展需求,可是如何進行分佈式應用診斷成爲挑戰。雖然,業內有鏈路追蹤相關的開源解決方案,但存在着研發投入較高、自建成本較高、技術風險較大、運維難度較大的挑戰。網絡
鏈路追蹤 Tracing Analysis源自阿里巴巴內部的通過大規模實戰驗證過的 EagleEye,基於 Opentracing 標準,全面兼容開源社區,可實現 Jaeger, Zipkin 和 Skywalking等開源方案在阿里雲上的託管,客戶無需搭建基礎設施,節省運維投入和技術風險。同時,支持多語言客戶端將應用的鏈路數據上報至鏈路追蹤控制檯,實現鏈路追蹤的目的。架構
據介紹,鏈路追蹤 Tracing Analysis 可用於鏈路拓撲分析,慢請求、異常請求、流量異常的問題發現和定位,並能夠根據業務Tag 對業務進行統計。以某教育行業客戶爲例,鏈路追蹤 Tracing Analysis 幫助客戶將異常請求數從原先的3%下降到0.1%,排查5個以上線上問題。運維
此外,鏈路追蹤 Tracing Analysis可幫助用戶收集全部分佈式微服務應用和相關PaaS產品的分佈式調用信息,查看應用的依賴路徑,用於業務分析和穩定性評估。以某金融行業客戶爲例,鏈路追蹤 Tracing Analysis 幫助客戶將將應用的平均響應時間從2秒下降到500毫秒。異步
值得注意的是,鏈路追蹤 Tracing Analysis 省去了客戶自建基礎設施的本地存儲費用,僅經過雲端日誌存儲收取存儲費用,整體的機器成本是自建全鏈路追蹤系統的1/5或更少,並提供了天天1000請求數的無償使用額度。分佈式
目前,阿里雲鏈路追蹤 Tracing Analysis已應用於金融、遊戲、教育、零售、人工智能等多個行業,幫助開發者高效的分析和診斷分佈式應用架構下的性能瓶頸。微服務
Q&A:性能
Q1:能夠經過 API 拉取鏈路追蹤的數據嗎?
A1:支持,收集的鏈路能夠經過OpenAPI的方式獲取,也能夠嵌入鏈路追蹤的頁面展現,也能夠直接在日誌服務中查看。
Q2:非阿里雲服務,能夠接入鏈路追蹤?
A2:鏈路是追蹤是開放的,只要客戶的應用能夠訪問公網,就能夠接入,和有沒部署在阿里雲上不要緊。
Q3:埋點對性能的影響有相關分析麼?A3:埋點數據是異步批量上報的,會對性能有影響有限,通常在1%左右,主要看埋點的量,埋的多會影響大一點。從目前的壓測數據來看,對性能影響比較小。