2021-01-28 分類: 網(wǎng)站建設
服務網(wǎng)格(Service mesh)已經(jīng)不是一個新鮮概念,但它實現(xiàn)了連接運行在Kubernetes作為容器化平臺之上的微服務,這使得服務網(wǎng)格的想法更加流行。如果沒有服務網(wǎng)格,每個微服務都需要配置以接收(或發(fā)送)連接到其他需要與之通信的微服務,但服務網(wǎng)格完全改變了這一狀況。
與此前需要手動配置以及投入大量的時間精力來維護微服務之間的連接所不同的是,開發(fā)人員現(xiàn)在可以創(chuàng)建一個網(wǎng)格,使得微服務彼此通信可靠、可控以及安全。Kubernetes和服務網(wǎng)格是相互作用的,主要是因為使用服務網(wǎng)格可以在不增加工作量的情況下,實現(xiàn)更復雜的容器化架構(gòu)。
因此,有很多方式可以在Kubernetes頂層建立一個服務網(wǎng)格。在本文中,我們將比較一些你可以用于建立服務網(wǎng)格的工具,你可以分別了解到它們的優(yōu)劣勢進而選出最適合自己的服務網(wǎng)格工具。
官網(wǎng):https://aws.amazon.com/app-mesh/
由于現(xiàn)在許多基于Kubernetes的應用程序和微服務都運行在Amazon Web Services環(huán)境中,所以很難不談到AWS App Mesh。顧名思義,AWS App Mesh是亞馬遜自己的服務網(wǎng)格,用于為Amazon services創(chuàng)建服務網(wǎng)格層。
作為亞馬遜的產(chǎn)品,AWS App Mesh利用結(jié)合了Envoy的專有技術(shù)作為其服務代理。AWS App Mesh通過創(chuàng)建虛擬服務在相同的命名空間中連接服務。 在你的AWS環(huán)境中每個微服務都可以找到虛擬服務并使用它來與其他微服務通信。
AWS App Mesh與其他服務(例如EKS、Fargate和EC2)的無縫集成是其最強的優(yōu)勢,但在使用App Mesh的過程中存在一些限制。首先,你不能將App Mesh遷移到外部或者在多云設置中使用這一服務。
App Mesh還借助CloudWatch和AWS X-Ray來管理服務網(wǎng)格,這意味著你可以在不離開主儀表板的情況下完全控制該層。諸如支持mTLS和高級負載均衡的特性在App Mesh中也有,但是它不支持身份驗證規(guī)則。
官網(wǎng):https://istio.io/latest/zh/
Istio可能是最流行的Kubernetes服務網(wǎng)格工具,它最初由Lyft開發(fā),但后來變成Lyft、Google和IBM聯(lián)合開發(fā)??紤]到Kubernetes背后的公司是谷歌,那么Istio被廣泛用于許多部署類型也并不奇怪了。
與App Mesh類似,Istio也將Envoy用作其服務代理,但它并沒有限制你把Envoy作為唯一的ingress controller。Istio的獨特之處在于它提供了巨大的靈活性。你可以將Istio用于其他的容器化平臺,但其與Kubernetes的無縫銜接使其發(fā)揮的作用更大。
例如,Istio支持mesh擴展和多云網(wǎng)格,這兩個特性在App Mesh和其他服務網(wǎng)格工具里都是沒有的。Istio還可以處理流量訪問控制以及負載均衡,就像它是為了執(zhí)行這些任務而構(gòu)建的一樣。它甚至支持故障注入和延遲注入。
使用Istio的唯一缺點是你可能會對它提供的功能感到不知所措。如果你有足夠的資源使用Istio處理服務網(wǎng)格層,這個工具有可能通過其功能簡化最復雜的微服務架構(gòu)。
官網(wǎng):https://linkerd.io/
當Linkerd發(fā)布2.x版本時,它已經(jīng)是一個十分流行的服務網(wǎng)格工具了。新版本受到了Kubernetes社區(qū)的歡迎,截止到2020年4月中旬,其2.7.1穩(wěn)定版已經(jīng)出爐。它完全是作為一個獨立的服務網(wǎng)格工具來構(gòu)建的,所以它并不依賴Envoy等第三方工具來管理,它甚至還包含了linkerd-proxy作為服務代理。
最近的升級還包括dashboard的改進和針對金絲雀部署的流量拆分功能的可視化。這使其成為實時監(jiān)控和編排金絲雀和藍綠部署的好工具。
在保持獨立的同時,Linkerd還與Ingress controller保持高度兼容性。實際上,Linkerd能夠與你使用的任意Ingress controller一起工作,使它在這方面最為靈活。一個簡單的linkerd inject命令就可以讓服務網(wǎng)格與你的應用程序集成。
Linkerd2 也是高度優(yōu)化的,安裝僅需60秒。如果你正在尋找可以帶來好性能的服務網(wǎng)格工具,那么Linkerd是你可以考慮嘗試的。作為一個非侵入式的服務網(wǎng)格工具,Linkerd在部署之后并不需要進行大量的優(yōu)化。開箱即用的配置足以支持復雜的微服務架構(gòu),并且能夠防止重大工具。Linkerd通過mutual TLS(mTLS)加密來增強應用程序的安全性。
Linkerd也是一個專門為Kubernetes開發(fā)的工具。它可能不支持多云和多集群網(wǎng)格創(chuàng)建,但這絲毫不會減弱其作為Kubernetes實例的服務網(wǎng)格層的能力。除此之外,它也可以與OpenCensus配合使用,從而使跟蹤和管理變得非常容易。
官網(wǎng):https://kuma.io/
Kuma將Envoy作為服務代理并且支持任意ingress controller。這與Consul Connect十分類似(該工具我們稍后會介紹),但Kuma也有自己令人耳目一新的功能。而且這些新意可能是因為Kuma是這個列表中最新的工具。
不要被Kuma年輕的年齡所欺騙了,它不僅僅已經(jīng)生產(chǎn)就緒,而且還具備了你所期望的服務網(wǎng)格工具的功能。它支持所有與OpenTracing兼容的所有后端并且允許你在需要時使用外部CA證書。不過,這一工具也存在不完善的地方——有一些功能是缺失的。
目前,在Kuma中沒有辦法進行基于路徑或基于請求頭的流量分割。它也不支持諸如流量訪問控制和指標等功能。這些功能也許會在后續(xù)版本中引入,但現(xiàn)在你必須得手動制作代理模板來彌補這些功能的缺失。
但是,Kuma作為一個服務網(wǎng)格工具還是很有前途的,盡管目前它只是0.4.0版本,但其開發(fā)者十分關(guān)注社區(qū)的意見并且十分樂意滿足用戶的要求,從這個維度上看,這個工具無疑是極具競爭力的。
官網(wǎng):https://www.consul.io/
由HashiCorp推出的Consul Connect可以與Envoy及其他各種服務代理一起工作,它還可以與任何ingress controller一起工作,這使其成為最容易集成到現(xiàn)有Kubernetes集群中的工具之一。
在任意Consul環(huán)境中Consul Connect都可以無縫銜接,但是它也只能在Consul環(huán)境中工作。雖然該服務網(wǎng)格工具提供了許多方便的功能,但它是為了能與其他HashiCorp產(chǎn)品使用而設計的。不過,這些工具的應用十分廣泛。
從TCP到gRPC的一切都支持,此外這一工具還能與Kubernetes、VM甚至Nomads一起工具。網(wǎng)格擴展也是完全支持的,所以你可以擁有一個跨多個云服務和集群的環(huán)境,并且仍然具有一個支持微服務的功能強大的服務網(wǎng)格層。
Consul Connect需要改進的一個方面是監(jiān)控。然而,你也可以整合其他監(jiān)控工具,以便獲得日志和每個路由的指標。你甚至可以集成諸如Prometheus和Grafana等工具來可視化你的監(jiān)控數(shù)據(jù)。然后你只需要從你的服務代理中提取數(shù)據(jù)即可。
這些服務網(wǎng)狀工具基本設計為Envoy作為服務代理。與其他邊緣代理工具相比,Envoy確實具有一些優(yōu)勢,其中高級負載均衡是最突出的優(yōu)勢。
自動重試、區(qū)域本地負載均衡、request shadowing等功能可以讓你配置流量負載均衡以獲得大性能。另一方面,高可觀察性使得Envoy成為維護支持能力強大架構(gòu)的網(wǎng)絡的好解決方案。
當然,這些工具有一個主要目標:創(chuàng)建一個云架構(gòu),在這個架構(gòu)中,微服務可以以可靠和安全的方式彼此通信。好消息是,無論你使用哪種工具,你都能實現(xiàn)這個目標。
分享題目:6大服務網(wǎng)格工具比較
網(wǎng)頁網(wǎng)址:http://jinyejixie.com/news30/97830.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供標簽優(yōu)化、微信小程序、全網(wǎng)營銷推廣、響應式網(wǎng)站、企業(yè)網(wǎng)站制作、網(wǎng)站營銷
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容