文章轉載來源《千家網》
你推出了一個新的物聯網產品,可能使用AWS、Azure或其他主要云提供商提供的物聯網框架,你的設備現在可以從云發送和接收數據。那么,如何處理這些數據以獲得有價值的見解,例如設備健康遙測或用戶行為跟蹤?有許多不同的方法可以在云中建立數據處理基礎設施,以平衡控制和復雜性。無服務器架構最終是一種軟件設計原則,它允許您在不管理基礎設施的情況下構建、擴展和運行服務,而MistyWest對這種“無服務器”模式如何使團隊能夠快速構建和擴展云解決方案感到興奮。
為了幫助您理解這對于物聯網產品解決方案的適用性,我們提供了以下不同架構模式的概述,以及您應該在什么情況下考慮為您的項目采用無服務器。
使用虛擬機
現在,設置云管道的老派方法(如果希望獲得更多控制,推薦使用這種方法)是在云中啟動一個虛擬機(VM)來運行處理代碼。Azure虛擬機、AWS EC2或GCP計算引擎是一些常見的選項。你得到一個虛擬計算機,它可以運行類似于在你的個人計算機上運行的代碼。然而,這種路由的局限性是,您將迅速耗盡單個VM的處理能力,特別是當您正在處理來自數千個物聯網設備的數據時。
要獲得更強的處理能力,可以添加更多vm并將處理工作分配給多臺計算機。像Kubernetes和Docker Swarm這樣的工具可以讓您跨多臺機器編排處理工作負載,云提供商提供AWS Elastic Kubernetes Service和谷歌Kubernetes Engine這樣的服務,以支持在云中跨多臺機器編排工作負載。像AWS Elastic Beanstalk或Azure App Services這樣的服務可以自動設置和擴展常見的web開發框架,如Django、Rails和Node,它們是很好的起點服務,可以幫助你管理它們。
然而,設置和配置編排工具可能是復雜的,需要大量的時間和專業知識,不能直接為客戶提供價值。如果你想快速構建原型,為客戶提供價值,并且你知道你的解決方案可以擴展,那么無服務器可能是正確的選擇。
什么是無服務器架構?
無服務器架構允許您將服務器管理完全卸載給云提供商,同時可以直接專注于應用程序代碼。一個更常見的體系結構子集是功能即服務(FaaS)。但無服務器體系結構提供的服務遠不止這些——從數據庫和隊列系統到事件處理服務,每個云服務提供商都提供各種各樣的服務來滿足您的需求。
圖1–多個手動配置的服務器
無服務器化的好處
1.收費:一個好處是,無服務器平臺傾向于根據無服務器功能運行的頻率和時間來收費,所以您只需要為所使用的計算時間付費。這可以在開發過程中保持較低的成本,同時以一種在發行過程中自動擴展的方式進行構建。
2.快速響應:無服務器函數也傾向于快速響應需求峰值,因為平臺會自動增加可用的計算能力來運行函數,然后在負載減少時降低計算能力。這可以有效地利用資源,只在需要時部署計算能力。
3.語言選項:對各種編程語言都有很好的支持,所以您很可能可以用您選擇的語言構建無服務器函數。例如,AWS Lambda本機支持Java、Go、PowerShell、Node.js、c#、Python和Ruby,并提供了一個運行時API來允許使用其他編程語言。Azure函數支持c#、Javascript、f#、Java、Powershell、Python和Typescript。
4.Bug預防:使用無服務器功能進行構建必然會創建一個無狀態和無主機的系統,這可以簡化對系統的推理,并防止一些關于狀態管理的復雜Bug。
5.數據管道:通過您的物聯網框架,您可以設置自動的、事件驅動的數據管道觸發器和數據庫存儲。通過附加的可視化框架或開發您的內部儀表板,您可以立即監視進度。
6.少花錢:如果你的VM運轉起來了,那么不管你是否充分利用了這些資源,還是它只是閑置著,你都要花錢。如果你的物聯網設備很少發送小的數據包,這就不是理想的,即使你有數千個設備不斷傳輸數據,在包之間也會有很多空閑時間,這將是非常低效的。利用無服務器框架可以讓你只為你使用的東西付費,并且可以在不需要任何配置更改的情況下為你處理擴展——無論你有一臺設備還是一百萬臺設備。此外,如果您使用的是Azure,正如《荒野中的無服務器》一文中最初提出的那樣,通過讓它預測調用,您將能夠顯著減少冷啟動。
圖2–在無服務器平臺上運行的功能
無服務器化的弊端
1.更少的控制:使用無服務器平臺的一個缺點是,您對運行代碼的實例的控制更少,因為您無法控制底層硬件的配置。在無服務器環境中,對處理能力、內存和處理時間的限制可能是一種局限,而在虛擬機中,您可以進行相當大的垂直擴展。
2.長延遲:另一個缺點是,由于平臺在需求高峰期間處理增加可用計算能力(即啟動更多虛擬機來運行功能),當用戶必須等待虛擬機啟動時,您對延遲的控制力度較低。這有時會導致第一次請求的長延遲,稱為“冷啟動延遲”,這可能是對延遲高度敏感的應用程序中的一個問題,盡管這通常不是一個問題。
彈性結構
網上有許多關于無服務器架構的成本比較;我們發現媒體上的無服務器轉換和燃燒和尚的分析非常有幫助。無服務器架構非常適用于物聯網解決方案,并且越來越受歡迎。隨著當今世界上數十億物聯網設備的使用,擁有一個彈性架構對于快速投入生產至關重要。使用無服務器架構構建將讓您快速原型化,快速失敗,并從長遠來看擊敗您的競爭對手——只需注意所有的底層屬性,以便最大限度地利用您的資金。
作者:Jason Choi