影音先锋男人资源站_国产婷婷综合丁香亚洲欧洲_白狐视频传媒污软件下载_趁女同学午休揉她的屁股

阿里云2020年從架構(gòu)談起到Mesh結(jié)束,阿里云最新規(guī)劃消息-ESG跨境

阿里云2020年從架構(gòu)談起到Mesh結(jié)束,阿里云最新規(guī)劃消息

來源網(wǎng)絡(luò)
來源網(wǎng)絡(luò)
2022-05-08
點贊icon 0
查看icon 624

阿里云2020年從架構(gòu)談起到Mesh結(jié)束,阿里云最新規(guī)劃消息阿里云2020年從架構(gòu)談起到Mesh結(jié)束作者 張羽辰(同昭)阿里云交付專家導(dǎo)讀:如今,幾乎所有的事情都離不開軟件,當(dāng)你開車時,腳踩上油門,實際上是車載計算機通過力度感應(yīng)等計算輸出功率,最終來控制油門,你從未想過這會是某個工程師的代碼。當(dāng)我們談?wù)摷軜?gòu)時,我們到......

阿里云2020年從架構(gòu)談起到Mesh結(jié)束,阿里云最新規(guī)劃消息




阿里云2020年從架構(gòu)談起到Mesh結(jié)束

作者 張羽辰(同昭)阿里云交付專家

導(dǎo)讀:如今,幾乎所有的事情都離不開軟件,當(dāng)你開車時,腳踩上油門,實際上是車載計算機通過力度感應(yīng)等計算輸出功率,最終來控制油門,你從未想過這會是某個工程師的代碼。

當(dāng)我們談?wù)摷軜?gòu)時,我們到底在談?wù)撌裁?/strong>

面向?qū)ο缶幊毯瘮?shù)式模塊化設(shè)計微服務(wù)這些詞匯貌似都和架構(gòu)這個 buzzword 有點關(guān)系,的確我們這個領(lǐng)域充滿了很多難以理解的詞匯,這些詞匯從英語翻譯到中文已經(jīng)喪失了部分上下文,再隨著上下文的改變使得意義徹底扭曲,比如:引擎、框架、架構(gòu)、應(yīng)用、系統(tǒng)……誠然大家都或多或少對這些詞語達成共識,在工作中使用這些詞匯進行溝通,某時就是指“我們都懂的那個東西”,但是在我深入的想聊聊架構(gòu)或者說軟件架構(gòu)時,的確不得不問自己這個問題,我們到底是談?wù)撌裁?/p>

事實上,架構(gòu)這個詞根據(jù)上下文所確定的范圍較為固定,建筑學(xué)上的架構(gòu)指代房屋結(jié)構(gòu)、整體設(shè)計、組合構(gòu)成等,而這些 highlevel 設(shè)計往往并不需要全面了解底層,就像使用 RestTemplate 進行 WebService 調(diào)用時,我們也不關(guān)心 socket 是在四層連接的一樣,因為細節(jié)被隱藏了。

但是,建筑學(xué)上的架構(gòu)與軟件架構(gòu)卻又極大的不同之處,問題出現(xiàn)在“軟件”這個詞上,按照 software 的詞解,ware 是指產(chǎn)品一樣的東西,而 soft 則強調(diào)易變,這是與 hardware 所對應(yīng)的。我們希望“軟件”能夠進行快速的修改,應(yīng)該能夠快速響應(yīng)甲方或者客戶的需求,所以軟件架構(gòu)必然不像建筑架構(gòu)一樣,建筑一經(jīng)建成,修改的成本極高,而軟件應(yīng)該走對應(yīng)的方向,發(fā)揮易于修改的特點。

“現(xiàn)在的大多數(shù)軟件非常像埃及金字塔,在彼此之間堆建了成千上萬的磚塊,缺乏結(jié)構(gòu)完整性,只是靠蠻力和成千上萬的奴隸完成。” —— Alan Kay。筆者認為,雖然這句話表達的意思我很贊同,但實際上,金字塔作為帝王的陵墓,是有著完整的設(shè)計邏輯,并且隨著好幾座金字塔的迭代的,以及逐漸完備的施工管理,后期金字塔是非常杰出的建筑代表,并作為地球上最高的人造建筑持續(xù)了好幾千年。關(guān)于金字塔是否由奴隸建造還是存有爭議。(圖片來自 Isabella Jusková @ Unsplash)。

作為工程師,我們一方面關(guān)注軟件產(chǎn)品的能力和行為,這往往是一個項目的起點,另一方面我們需要關(guān)注軟件的架構(gòu)設(shè)計,因為我們希望設(shè)計有著彈性、易于維護、高性能、高可用的系統(tǒng),更希望系統(tǒng)能夠不斷演進,而不是在未來被推倒重做。所以,回正我們的視野,當(dāng)我們決心要設(shè)計一個好的架構(gòu)時,我們需要明確,架構(gòu)往往決定的是軟件的非功能性需求。這些非功能性需求有:

易于開發(fā):我們希望工程師一進入團隊就可以立刻開始進行研發(fā)工作,我們希望代碼易于閱讀與理解,同時開發(fā)環(huán)境足夠簡單統(tǒng)一,說到這里大家可以回想下當(dāng)你進入項目時,學(xué)習(xí)上下文的痛苦。當(dāng)我們開始采用 docker 輔助開發(fā)時,時任架構(gòu)師提出了一個要求,只要一行命令就可以使用 docker 啟動本地測試環(huán)境,而且必須所有的微服務(wù)都要做到這一點。痛苦的改造完成后,三年后進入項目的同學(xué)只需要安裝好 docker,再在 ternimal 中運行一句 ./rundev.sh 就能夠獲取一個具有完整依賴的本地環(huán)境,提效明顯。

方便部署:如果系統(tǒng)的部署成本很高,那使用價值就不會很高了,我們很多企業(yè)都存在那種動也不敢動,改也不敢改,停也不敢停的系統(tǒng),除了祈禱它別掛掉好像沒有別的辦法,或者很多企業(yè)都采用了 K8s 這種先進的編排系統(tǒng),但是在應(yīng)用部署和上線時,還是走的每周四變更的路子。現(xiàn)代的發(fā)布方式 AB、金絲雀、灰度無法采用是因為改造成本過高,或者沒有足夠的自動化測試來保證改動安全,更別提將發(fā)布做到 CICD 里面了。

易于運維:DevOps 的初衷是建立一種縮短運維與研發(fā)距離的文化,讓出現(xiàn)問題后更容易處理,希望讓大家將視野放在產(chǎn)品上而不是限定自己的工種,這并不是期望運維的同學(xué)能夠成為 Java 專家,迅速的進行 heap 分析發(fā)現(xiàn)問題,我們強調(diào)的是運維時的閉環(huán)能力。在軟件產(chǎn)品層面,我們也希望產(chǎn)品是足夠獨立的、自治,可以獨立部署,能夠做到橫向擴展,有著完整的可觀測性,畢竟當(dāng)今的硬件成本很多時候是遠遠小于人力的。

維護成本:隨著時間的推移,給軟件增加新功能就會變的越來越難,越是運行長久的項目就會陷入重寫還是重構(gòu)的苦惱。往往風(fēng)險在與,修改代碼會增加破壞已有功能的風(fēng)險,而且技術(shù)債也會越來越多難以償還,即使是重寫某些功能和模塊,我們也很難確定是否真的覆蓋到了所有的功能,簡而言之,dont break anything 的確很難做到。

以及最重要的一點,演進能力:良好的架構(gòu)設(shè)計應(yīng)該能讓系統(tǒng)處于易于演進的狀態(tài),能夠?qū)崿F(xiàn)給飛馳的汽車換輪胎的能力,而不會被框架、底層的某種數(shù)據(jù)庫、操作系統(tǒng)或者其他東西所綁架,但是這太難以做到了。的確,在項目進行技術(shù)選型時,因為某種數(shù)據(jù)庫的特性而有傾向,但是在上層設(shè)計中,我們必須保證不依賴于數(shù)據(jù)庫的特性,而將使用這些特性的地方放到底層細節(jié)中。我們也需要考慮,不使用 Spring 提供的 Dependency Injection,我們該如何組織我們的 beans,也要考慮將來系統(tǒng)的前端是 web 還是 mobile 還是都要支持

這里引用 Robert C·Martin(Uncle Bob)的原語,“軟件產(chǎn)品是有兩方面的價值,一方面是實現(xiàn)功能的價值,另一方面是架構(gòu)的價值,而架構(gòu)的價值可能更重要一些,因為它代表著軟件 soft 的特性。”

本書例子過少,而且缺乏現(xiàn)有流行框架的重構(gòu)或者改進建議,有點形而上,但是在方法論層面筆者還是認為值得一讀。Robert C·Martin 對數(shù)據(jù)庫(特指 RDBMS)的態(tài)度很值得討論,首先他認為數(shù)據(jù)庫是一種細節(jié),在架構(gòu)中應(yīng)該與業(yè)務(wù)解耦,他強調(diào)業(yè)務(wù)代碼與數(shù)據(jù)庫的無關(guān)性。同時在我們的代碼進行計算時,表格往往不是理想的數(shù)據(jù)結(jié)構(gòu),比如有些場景會使用樹、DAG 等等。可以回想一下,當(dāng)你需要把一個樹存入數(shù)據(jù)庫時,你該如何實現(xiàn)

微服務(wù)是一種軟件架構(gòu),不要擴展它

根據(jù)我們之前的討論,后端系統(tǒng)采用微服務(wù)是不會影響到其功能上的價值,本質(zhì)上微服務(wù)化和單體應(yīng)用的差別并不會表達在功能上,很多微服務(wù)進展不順利的同學(xué)會經(jīng)常說到:這東西用單體寫早就完事兒的確是這樣,這側(cè)面也印證了微服務(wù)只是一種軟件架構(gòu),而不是別的神奇的東西,并不是某個業(yè)務(wù)需求必須要使用微服務(wù)完成,我們看中微服務(wù),也是看中了架構(gòu)方面的優(yōu)勢,即那些非功能性需求。也有人使用 pattern 來描述它,也有人說和 SOA 基本上是一個東西,只是粒度不同,所以我們一開始就別相信這個世界有靈丹妙藥,也別期望有個什么技術(shù)能夠瞬間替代 Oracle。

作為開發(fā)“企業(yè)級后端應(yīng)用”的同學(xué),我們經(jīng)常會面臨很多非業(yè)務(wù)需求上的苦惱:有時我們需要同時支持移動端、移動 web、桌面端三種客戶端;有時候我們需要支持不同的協(xié)議比如 JSON 或 XML;有時我們又需要使用不同的中間件傳遞消息;或者在研發(fā)時,我們知道有一個地方寫的不好,我們想在未來補課重構(gòu);我們想嘗試最新的技術(shù)但是代價過高;系統(tǒng)無法擴容,或者成本極高;系統(tǒng)過于復(fù)雜無法在本地運行導(dǎo)致極低的效率……這些苦惱才是采用微服務(wù)的主要驅(qū)動力,回到我們對軟件架構(gòu)的討論之中,我們希望的是通過足夠松耦合的獨立服務(wù),來降低組件之間變化的成本,也就是說今天更新發(fā)快遞通知的功能,并不會影響到用戶查看購物車,也不會讓研發(fā)人員半天改完,再等三天才能上線。

但是世界上沒有免費的午餐,雖然我們知道微服務(wù)有很多很好的特性,比如組件即服務(wù)、松耦合、獨立部署、面向業(yè)務(wù)、高維護性、高擴展性等等,這里并不想展開討論它的好處,我們先考慮投入成本。假設(shè)我們每個同學(xué)都完整的學(xué)習(xí)了微服務(wù)的所有知識,對市面上的框架、產(chǎn)品非常熟悉,摩拳擦掌準(zhǔn)備開始,在拆解完幾個服務(wù)后,我們會發(fā)現(xiàn),沒有足夠的自動化手段,靠手動的方式進行測試、編譯、部署、監(jiān)控,這是顯而易見的會降低體驗,如果沒有優(yōu)化好的部署策略,所有的服務(wù)都在某個發(fā)布日上線,那更是一種災(zāi)難。

隨著規(guī)模的擴大,單體應(yīng)用的代碼改動成本會越來越大。很多時候我們微服務(wù)的架構(gòu)實踐是存在誤區(qū)的,我們總認為流量經(jīng)過某個 gateway 后直達某個服務(wù),確忽視了服務(wù)之間調(diào)用的場景,理想的微服務(wù)架構(gòu)應(yīng)該是一張網(wǎng),每個節(jié)點都是獨立的、自治的服務(wù)。

一些之前使用單體很容易做到的場景,在分布式的環(huán)境下會更加困難。比如我們可以通過 RDBMS 提供的數(shù)據(jù)庫事務(wù)來支撐一致性,但是如果訂單服務(wù)和價格服務(wù)分離,勢必要進行分布式事務(wù)來保證一致性(往往是最終一致性),而分布式事務(wù)的成本和難度就不用贅述了。在單體環(huán)境下,我們可以很輕松的使用切面進行權(quán)限驗證,而在微服務(wù)的場景中,服務(wù)之間相互調(diào)用是難以控制的。

拆分服務(wù)或者服務(wù)邊界劃分是另一件很難做到的事情,最吃香的理論也許是根據(jù) DDD 去進行劃分,天然的領(lǐng)域或者子域(domain)貌似都能對應(yīng)一個服務(wù),因為足夠的界限上下文(bounded context)能夠保持服務(wù)的獨立性,使其細節(jié)被隱藏在界限之內(nèi),聽起來是個不錯的主意。但是現(xiàn)實卻十分殘酷,使用 DDD 生搬硬套去進行軟件開發(fā)的例子不在少數(shù),成功例子也難以復(fù)制。

雖然我在實踐中也經(jīng)常使用業(yè)務(wù)領(lǐng)域去進行服務(wù)劃分,但是我并不認為這是 DDD 的做法,沒有必要規(guī)定有多少個 domain 就有多少服務(wù),也不需要規(guī)定 sub domain 能否獨立服務(wù)。與其進行頂層設(shè)計一攬子的解決方案,我更相信演進的力量,如果你真的需要拆分一個服務(wù),足夠的基礎(chǔ)設(shè)施與自動化工具應(yīng)該允許你低成本的去做,而不是一開始就畫好所有的架構(gòu)圖。這就跟所有的改革一樣,革命派往往不是一步功成,而是逐漸的積累的。所以使用微服務(wù),當(dāng)你能夠負擔(dān)的起(only you can afford it),也表示你能負擔(dān)的失敗一樣,技術(shù)世界不存在一蹴而就,all in 非常危險。

衛(wèi)報網(wǎng)站(Guardian)的微服務(wù)改造就是一個很好的例子,網(wǎng)站核心依舊是一個巨大的單體,但是新功能通過微服務(wù)實現(xiàn),這些微服務(wù)調(diào)用單體所提供的 API 來完成功能。對于常常出現(xiàn)的市場活動(比如某個體育比賽的專用板塊),這種方式能夠快速實現(xiàn)活動頁面與功能,完成業(yè)務(wù)需求,并在活動結(jié)束后刪除或丟棄。我之前參與項目中,也通過等量替換與重構(gòu),慢慢絞殺(Strangler Pattern)掉一個巨大的陳舊的 JBoss 應(yīng)用。

PlayStation 首席設(shè)計師 Mark Cerny 在今年的 PS5 新主機的技術(shù)分享中提到,游戲主機需要平衡好演進與革命(balance the evolution and revolution),我們不想丟掉多年來開發(fā)者的積累,在復(fù)用過去的成功經(jīng)驗時,我們也希望大家能夠使用更先進的技術(shù)。

人人都愛恨 Spring Cloud

看起來,在 Java 世界中,Spring Cloud 貌似是微服務(wù)的最優(yōu)解了,甚至在很多同學(xué)的簡歷上,Spring Cloud 幾乎可以和微服務(wù)劃等號了,不止一次的有人告訴我說:公司的技術(shù)棧不是 Java,所以搞不了微服務(wù)很難受,并不是我沒有學(xué)習(xí)精神和冒險精神云云。很遺憾,對于軟件架構(gòu)來說,跟可沒有規(guī)定編程語言,設(shè)計模式不是也出了很多版本嗎歸根結(jié)底還是 Spring Cloud 的全家桶策略更吸引人,什么事兒都不如加上幾個 jar 就能擁有的神奇次時代架構(gòu)更有吸引力。

不可否認,我在學(xué)習(xí) Spring Cloud 的時候也驚嘆其完整性,幾乎常見的微服務(wù)需求都有足夠完整的解決方案,而大多數(shù)方案是做在應(yīng)用層,具有良好的適配性,比如 eurake 的注冊發(fā)現(xiàn)、zuul 網(wǎng)關(guān)與路由、config service、hystrix circuit breaker 等等,通過統(tǒng)一的編程范式(基于 annotation 的注入與配置),足夠豐富的功能選擇(常用功能甚至都有兩種選擇),以及較好的集成方式。前有 Netflix 的成功經(jīng)歷,后隨著微服務(wù)的浪潮,再加上足夠龐大的 Java 社區(qū),可以說是王道中的王道。但并非 Spring Cloud 沒有弱點,反倒這些功能設(shè)計與隨后的容器化浪潮產(chǎn)生了分歧,至今融合 Spring Cloud 與 Kubernetes 都是熱門話題,這里我們展開說說它的不足或者限制(limitation)。

侵入性與語言綁架

這可能是最大的問題,基本只能使用 Java 作為研發(fā)語言,這一點在國內(nèi)也備受爭議,因為不論是作為架構(gòu)師還是入門的程序員,都需要嘗試新的技術(shù)棧來進行儲備或是采用新的功能,而且比如使用自制的 client 去實現(xiàn) ribbon 的負載均衡也是很難的,但是如果不用 Java,做到這一點也很難,不是說 Java 語言不夠優(yōu)秀,而是我們對未來應(yīng)該有更多的選擇,對于一個技術(shù)公司來說編程語言應(yīng)該不會成為限制,試問這個時代誰不想學(xué)習(xí)一點 golang 或者 rust 或者 scala 呢其他服務(wù)比如 SSO、Config Service 也過于整體,如果想進行某項適配,則必須進行大量的修改(還好是開源的)。我們很擔(dān)心這種情況都會隨著框架的老去而面臨推到重來的境界,Ruby on Rails 可能就是前車之鑒吧。侵入性是另一個問題,還記得我們在討論軟件架構(gòu)時所提倡的實踐規(guī)則嗎盡量不要讓頂層設(shè)計依賴底層的框架或者某種細節(jié),但是滿屏幕的 annotation 與 jar 的直接引用,無疑告訴我們想去掉它們還是非常難的。

云原生的融合問題

對于云原生,不論是 CNCF 還是 Pivotal (VMWare)都在強調(diào)容器化、微服務(wù)、面向云環(huán)境等,CNCF 圍繞 Kubernetes 開始發(fā)展壯大,也隨著這種先進的容器編排技術(shù)的流行人們漸漸發(fā)現(xiàn)它和 Spring Cloud 在功能上還是存在很多重疊,雖然 k8s 與 IaaS 沒有重疊,但是現(xiàn)在還有多少廠商再推純 IaaS 呢既然有功能重疊,就有取舍,考慮到 Spring Cloud 的全家桶屬性,這個分歧處理一直都不能很好的解決。

集中式的資源

不論是 Config 、Eureka 都是聚合的單點,及時它們有集群的方式達到近乎 100% 的可靠性,但在邏輯架構(gòu)上,所有的微服務(wù)都依賴它們,這些集中式的資源的耦合是非常強的,它們會一直存在在你的生產(chǎn)環(huán)境之中,直到最后一個使用它們的系統(tǒng)下線。我們在架構(gòu)中需要避免使用共享的實例與資源,一個應(yīng)用不會因為不能寫日志而崩潰,也不應(yīng)該因為本地沒有 eureka 而無法啟動。

畏懼平臺綁定

誠然,在進程之內(nèi)解決服務(wù)注冊發(fā)現(xiàn)、負載均衡是很好的,它代表了最好了平臺無關(guān)性,但平臺的其他能力也很難享受的到了。綁定 k8s 貌似是個更好的選擇,因為相對于 Spring Cloud 它更靈活,也能做到不會被基礎(chǔ)的云平臺綁定,但也更難以掌握與運維。當(dāng)然我也不是認為 K8s 必須作為微服務(wù)的選擇,作為容器的編排平臺,它可以做更多的事情(比如跑數(shù)據(jù)庫、中間件等),運行微服務(wù)應(yīng)用只是其中之一。

方法論的落地能力

2020年已經(jīng)過了一半,從技術(shù)上來說,Serverless 已經(jīng)進入成熟期,Kubernetes 也更加成熟,已經(jīng)成為事實的標(biāo)準(zhǔn)。但是很多時候我們的方法論與架構(gòu)設(shè)計是跟不上的技術(shù)發(fā)展的,很多同學(xué)可能還在經(jīng)歷每周的發(fā)布日,很多同學(xué)還沒辦法改進團隊內(nèi)老舊的技術(shù),很多同學(xué)的 Jenkins 還是停留在打包的階段,很多同學(xué)機器上還是沒有安裝 docker,很多時候并不是框架或者平臺的問題,而是方法論還停留在過去。

保持演進

應(yīng)用程序也應(yīng)該踐行開閉原則,對擴展開放使得我們在未來有更多的選擇。微服務(wù)是一個很好的機會能讓我們真正的演進架構(gòu)而不需要付出過多的代價,當(dāng)我們需要組件化系統(tǒng)時,組件的關(guān)鍵特性正是可獨立替換或升級,我們可以不影響其他部分去進行替換和重構(gòu),這樣的成本是顯然低于拋棄舊的巨型框架而重寫的。有著正確的態(tài)度和工具,我們可以更快、更頻繁的控制變更,我們可以激進的選擇新的技術(shù)棧,也可以合并兩個耦合過緊的服務(wù),隨著服務(wù)的不斷聚合、抽出,你會發(fā)現(xiàn)系統(tǒng)的邏輯架構(gòu)會越來越清楚,再進行修改就會信心倍增了。我們可以針對每個服務(wù)使用不同的存儲技術(shù),我們可以使用 OSS 處理文件,而不是繼續(xù)往 Oracle 里面塞圖片和視頻。

Istio 的解法與問題,以及 Mesh 還缺少什么

這個開幕雷擊雖然槽點滿滿,但并沒有降低社區(qū)對 Istio 的信心,反倒是漸漸發(fā)現(xiàn)這次的大改動使 Istio 變得有點好用了,可以在生產(chǎn)中采用而不需要付出太多代價了。當(dāng)然,漂亮話永遠好說。

2017 年的時候 Service Mesh 還是一個襁褓中的概念,現(xiàn)在已經(jīng)成為了微服務(wù)領(lǐng)域的未來之選,但遺憾的是目前只有 Istio 足夠成熟能代表這項技術(shù),當(dāng)然我也有幸實踐過類似的 Sidecar 來進行反向代理、日志收集、性能監(jiān)控、健康檢查等功能,但是距離 Mesh 的愿景還是有大的差距。

今天并不想展開 Service Mesh 或者 Istio 的優(yōu)勢,進程之外的解決方案能夠確保系統(tǒng)的靈活性,而流量控制、服務(wù)治理、端對端的傳輸安全、限流、發(fā)現(xiàn)注冊等等,我們希望工程師能夠聚焦業(yè)務(wù),實現(xiàn)架構(gòu)的靈活性,聚焦真正的價值,而剩下的進行配置就好。所以我想這也是 Serverless 被無限看好的原因,既然我們想 delegate 對基礎(chǔ)設(shè)施的控制,那為什么還需要關(guān)心容器呢Istio + k8s 的方案已經(jīng)足夠好,至少我們團隊正在認真學(xué)習(xí),在向客戶提供最佳實踐之前,我們依舊有很多問題需要解決,下面列出一些代表性的:

彈性與自恢復(fù)問題

使用系統(tǒng)度量、參數(shù)等觸發(fā)彈性伸縮是常見的需求,這里我們是使用云監(jiān)控還是自己搭一套我一直傾向數(shù)據(jù)與用途解耦,使用 pub sub 模式解決問題,比如 CPU 過高可能會觸發(fā)多個行為:觸發(fā)警報,觸發(fā)彈性規(guī)則,展示在 dashboard 上。我們可以增加 pod 來分擔(dān)服務(wù)的壓力,或者因為某個 pod 異常退出后,啟動新的 pod 來完成自恢復(fù),這系列動作也是需要我們自己解決的。

監(jiān)控與可觀測性

日志、警報等可觀測性的問題,這一方面的實踐較多,唯一比較擔(dān)心的是 ARMS 或者 Newrelic 這種 APM 功能目前沒在目標(biāo)平臺上實踐過,我們希望能夠清晰的看到每個服務(wù)的實時性能,目前這一部分還缺乏考慮與設(shè)計。

限流與降級的實踐

Istio 的流量控制能力是非常強大的,如何對服務(wù)采取降級、限流這種常見的治理操作,也是需要總結(jié)出實踐經(jīng)驗的。避免串流錯誤(cascade failure)在微服務(wù)領(lǐng)域也很常見,也需要避免故障蔓延。

多種自動化部署

藍綠、灰度、金絲雀,這些多樣的部署方式也需要落地,我們可能會寫一些 deployment util 之類的小腳本,部署的方式需要和 CICD 打通。一個部署工具,一個配置文件,一個 CICD 組成未來單個應(yīng)用的部署方式。

ABAC 與 OPA

基于屬性的權(quán)限控制以及 OPA 的可定制性我們是非常看好的,而且 sidecar 可以在進程之外解決權(quán)限驗證問題,的確值得嘗試,剛好也學(xué)習(xí)下 golang 用于定制 OPA。

Saga 與補償事件

分布式事務(wù)是微服務(wù)實踐中的大坑,我曾經(jīng)也寫過類似的文章,項目經(jīng)驗中更多的是將事務(wù)放在單一的服務(wù)內(nèi),再加上我自己也沒機會寫過真正的網(wǎng)店系統(tǒng)。補償事件也是常用的最終一致性方案,總之放在一起驗證。

高可用和混沌工程

基于 K8s 實現(xiàn)應(yīng)用的高可用應(yīng)該不難,容器的天生優(yōu)勢就是易于啟動與管理,如果隨機殺掉 pod 不會影響系統(tǒng)可用性,這就算是實現(xiàn)了類似于 SLB + ECS + ASG 的能力,真正危險的是其他 非業(yè)務(wù)型 pod,比如 istio 的各種 supervisor。

實踐微服務(wù),作為架構(gòu)師所考慮的東西遠遠大于只是實現(xiàn)業(yè)務(wù),但是一旦鋪平道路,下來的研發(fā)與迭代將會更加順利。


文章推薦
Twitter重構(gòu)了廣告平臺,twitter有哪些廣告位
Wish商家怎樣給店鋪上架產(chǎn)品,wish平臺訪問令牌已過期怎么處理
WhatsApp社交營銷工具全球推廣 WhatsApp不回郵件客戶一招制敵,中國如何使用whatsapp營銷
按設(shè)備和位置進一步細分搜索量和流量估算


特別聲明:以上文章內(nèi)容僅代表作者本人觀點,不代表ESG跨境電商觀點或立場。如有關(guān)于作品內(nèi)容、版權(quán)或其它問題請于作品發(fā)表后的30日內(nèi)與ESG跨境電商聯(lián)系。

搜索 放大鏡
韓國平臺交流群
加入
韓國平臺交流群
掃碼進群
歐洲多平臺交流群
加入
歐洲多平臺交流群
掃碼進群
美國賣家交流群
加入
美國賣家交流群
掃碼進群
ESG跨境專屬福利分享群
加入
ESG跨境專屬福利分享群
掃碼進群
拉美電商交流群
加入
拉美電商交流群
掃碼進群
亞馬遜跨境增長交流群
加入
亞馬遜跨境增長交流群
掃碼進群
亞馬遜跨境增長交流群
加入
亞馬遜跨境增長交流群
掃碼進群
拉美電商交流群
加入
拉美電商交流群
掃碼進群
ESG獨家招商-PHH GROUP賣家交流群
加入
ESG獨家招商-PHH GROUP賣家交流群
掃碼進群
2025跨境電商營銷日歷
《2024年全球消費趨勢白皮書——美國篇》
《2024TikTok出海達人營銷白皮書》
《Coupang自注冊指南》
《eMAG知識百科》
《TikTok官方運營干貨合集》
《韓國節(jié)日營銷指南》
《開店大全-全球合集》
《TikTok綜合運營手冊》
《TikTok短視頻運營手冊》
通過ESG入駐平臺,您將解鎖
綠色通道,更高的入駐成功率
專業(yè)1v1客戶經(jīng)理服務(wù)
運營實操指導(dǎo)
運營提效資源福利
平臺官方專屬優(yōu)惠

立即登記,定期獲得更多資訊

訂閱
聯(lián)系顧問

平臺顧問

平臺顧問 平臺顧問

微信掃一掃
馬上聯(lián)系在線顧問

icon icon

小程序

微信小程序

ESG跨境小程序
手機入駐更便捷

icon icon

返回頂部