Serverless 架構的演進
The Serverless Framework (無伺服器架構)允許你自動擴充套件、按執行付費、將事件驅動的功能部署到任何雲。 目前支援 AWS Lambda、Apache OpenWhisk、Microsoft Azure,並且正在擴充套件以支援其他雲提供商。 |
Serverless 降低了維護應用程式的總成本,能夠更快地構建更多邏輯。它是一個 行工具,提供腳手架、工作流自動化和開發部署無伺服器架構的最佳實踐。它也可以透過外掛完全擴充套件。
十多年前主流的應用架構都是單體應用,部署形式就是一臺伺服器加一個資料庫,在這種架構下,運維人員會小心翼翼地維護這臺伺服器,以保證服務的可用性。
▲ 單體架構
隨著業務的增長,這種最簡單的單體應用架構很快就面臨兩個問題。首先,這裡只有一臺伺服器,如果這臺伺服器出現故障,例如硬體損壞,那麼整個服務就會不可用;其次,業務量變大之後,一臺伺服器的資源很快會無法承載所有流量。
解決這兩個問題最直接的方法就是在流量入口加一個負載均衡器,使單體應用同時部署到多臺伺服器上,這樣伺服器的單點問題就解決了,與此同時,這個單體應用也具備了水平伸縮的能力。
▲ 單體架構(水平伸縮)
1. 微服務架構演進出通用服務
隨著業務的進一步增長,更多的研發人員加入到團隊中,共同在單體應用上開發特性。由於單體應用內的程式碼沒有明確的物理邊界,大家很快就會遇到各種衝突,需要人工協調,以及大量的 conflict merge 操作,研發效率直線下降。
因此大家開始把單體應用拆分成一個個可以獨立開發、獨立測試、獨立部署的微服務應用,服務和服務之間透過 API 通訊,如 HTTP、GRPC 或者 DUBBO。基於領域驅動設計中 Bounded Context 拆分的微服務架構能夠大幅提升中大型團隊的研發效率。
2. 微服務架構給運維帶來挑戰
應用從單體架構演進到微服務架構,從物理的角度看,分散式就成了預設選項,這時應用架構師就不得不面對分散式帶來的新挑戰。在這個過程中,大家都會開始使用一些分散式服務和框架,例如快取服務 Redis,配置服務 ACM,狀態協調服務 ZooKeeper,訊息服務 Kafka,還有通訊框架如 GRPC 或者 DUBBO,以及分散式追蹤系統等。
除分散式環境帶來的挑戰之外,微服務架構給運維也帶來新挑戰。研發人員原來只需要運維一個應用,現在可能需要運維十個甚至更多的應用,這意味著安全 patch 升級、容量評估、故障診斷等事務的工作量呈現成倍增長,這時,應用分發標準、生命週期標準、觀測標準、自動化彈性等能力的重要性也更加凸顯。
▲ 微服務架構
1. 基於雲產品架構
一個架構是否是雲原生,就看這個架構是否是長在雲上的,這是對“雲原生”的簡單理解。這個“長在雲上”不是簡單地說用雲的 IaaS 層服務,比如簡單的 ECS、OSS 這些基本的計算儲存;而是應該理解成有沒有使用雲上的分散式服務,比如 Redis、Kafka 等,這些才是直接影響到業務架構的服務。微服務架構下,分散式服務是必要的,原來大家都是自己研發這樣的服務,或者基於開源版本自己運維這樣的服務。而到了雲原生時代,業務則可以直接使用雲服務。
另外兩個不得不提的技術就是 Docker 和 Kubenetes,其中,前者標準化了應用分發的標準,不論是 Spring Boot 寫的應用,還是 NodeJS 寫的應用,都以映象的方式分發;而後者在前者的技術上又定義了應用生命週期的標準,一個應用從啟動到上線,到健康檢查,再到下線,都有了統一的標準。
2. 應用生命週期託管
有了應用分發的標準和生命週期的標準,雲就能提供標準化的應用託管服務。包括應用的版本管理、釋出、上線後的觀測、自愈等。例如對於無狀態的應用來說,一個底層物理節點的故障根本不會影響到研發,因為應用託管服務基於標準化應用生命週期可以自動完成騰挪工作,在故障物理節點上將應用的容器下線,在新的物理節點上啟動同等數量的應用容器。可以看出,雲原生進一步釋放了價值紅利。
在此基礎上,由於應用託管服務能夠感知到應用執行期的資料,例如業務流量的併發、cpu load、記憶體佔用等,業務就可以配置基於這些指標的伸縮規則,再由平臺執行這些規則,根據業務流量的實際情況增加或者減少容器數量,這就是最基本的 auto scaling——自動伸縮。這能夠幫助使用者避免在業務低峰期限制資源,節省成本,提升運維效率。
在架構的演進過程中,研發運維人員逐漸把關注點從機器上移走,希望更多地由平臺系統管理機器,而不是由人去管理,這就是一個對 Serverless 的樸素理解。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31559985/viewspace-2745144/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Serverless 架構模式及演進Server架構模式
- Serverless 架構演進與實踐Server架構
- 從零入門 Serverless | 架構的演進Server架構
- Airbnb的架構演進AI架構
- 今日頭條架構演進之路——高壓下的架構演進專題架構
- 架構演進之「微服務架構」架構微服務
- 聊聊演進式架構架構
- 技術架構演進的思考架構
- Python後端架構演進Python後端架構
- 圖解分散式架構的演進圖解分散式架構
- 從MVC到DDD的架構演進MVC架構
- 統一接入層架構的演進架構
- 架構之:serverless架構架構Server
- 萬表商城Android架構演進Android架構
- vivo推送平臺架構演進架構
- Flutter Fish Redux架構演進2.0FlutterRedux架構
- Java分散式架構的演進過程Java分散式架構
- DBT、Airflow 和 Kubernetes的架構演進 - yanAI架構
- LBS定位系統架構是如何演進的架構
- 圖解分散式架構的演進過程!圖解分散式架構
- 有贊搜尋系統的架構演進架構
- Apache Druid 在 Shopee 的雲原生架構演進ApacheUI架構
- 淘寶10年的架構演進過程架構
- 資料治理:資料整合架構的演進架構
- 微服務事件驅動架構演進微服務事件架構
- 馬蜂窩支付中心架構演進架構
- hadoop 原始碼分析HDFS架構演進Hadoop原始碼架構
- 架構的演進, 阿里資深Java工程師表述架構的腐化之謎架構阿里Java工程師
- 架構的演進,阿里資深Java工程師表述架構的腐化之謎架構阿里Java工程師
- 架構設計之架構的演變架構
- 外賣客戶端容器化架構的演進客戶端架構
- 圖解分散式架構的發展和演進圖解分散式架構
- 荔枝架構實踐與演進歷程架構
- 研發協同平臺架構演進架構
- 億級流量系統架構演進之路架構
- MySQL資料庫架構——高可用演進MySql資料庫架構
- 技術架構分享:美團配送系統架構演進實踐架構
- 支付寶小程式 Serverless 服務架構演進 | mPaaS 線下沙龍 CodeDay#1 分享實錄Server架構