四、螞蟻SOFAMesh/MSON與istio的不同

學習完原生的istio, 再回頭來看螞蟻在service mesh的實現(xiàn),本文主要分析差異點
先獻上螞蟻的鏈接:https://www.sofastack.tech/projects/
重點看SOFAMesh和MOSN兩個項目

1、整體架構(gòu)

SOFAMesh 是基于 Istio 改進和擴展而來的 Service Mesh 大規(guī)模落地實踐方案。在繼承 Istio 強大功能和豐富特性的基礎(chǔ)上,為滿足大規(guī)模部署下的性能要求以及應對落地實踐中的實際情況,有如下改進:

  • 采用 Golang 編寫的 MOSN 取代 Envoy
    擴展理解:Envoy核心是用C++11編寫的

  • 合并Mixer到數(shù)據(jù)平面以解決性能瓶頸
    擴展理解: 因為Envoy發(fā)起每個請求前都需要對Policy服務進行Check請求,一方面增加了業(yè)務請求本身的延遲,一方面也給作為單點的Policy增大了負載壓力

  • 增強 Pilot 以實現(xiàn)更靈活的服務發(fā)現(xiàn)機制
    擴展理解:支持自家的SOFARegister

  • 增加對 SOFARPC、Dubbo 的支持
    擴展理解:螞蟻/阿里自家協(xié)議

下圖展示了SOFAMesh 和 Istio 在架構(gòu)上的不同:


image.png

2、SOFA Pilot

SOFA Mesh 項目 fork 了 Istio 項目,對 Pilot 的能力進行增強,目前在進行中的增強主要集中在下面三個方面:

  • 支持 Zookeeper 作為注冊中心,并在此基礎(chǔ)上支持 SOFA、DUBBO 等使用 Zookeeper 作為注冊中心的微服務框架。
  • 支持通用協(xié)議框架,使用一個通用協(xié)議,在 Kubernetes DNS 的基礎(chǔ)上同時支持多種協(xié)議。
  • 新增 register agent,支持 SOFA、DUBBO 和 HSF 的容器模型,即支持單個應用注冊多個服務實例。

3、MOSN

MOSN即Modular Open Smart Network-proxy 本質(zhì)上和Envoy一樣,還是代理嘛
核心不同點:
1、 MOSN用流量接管方案: 我理解是把sidecar的端口注冊到服務中心,最終調(diào)用的并不是真服務端口
資料: https://www.sofastack.tech/projects/sofa-mosn/concept/traffic-hijack/

2、Envoy用iptables流量劫持方案:我理解是直接劫持真服務端口
資料: https://jimmysong.io/istio-handbook/concepts/sidecar-injection-deep-dive.html

3、平滑升級:有點復雜,涉及到網(wǎng)絡深層原理了,讀下來的感覺就是MOSN方案更屌
資料: https://www.sofastack.tech/projects/sofa-mosn/concept/smooth-upgrade/

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容