摘要:相反,楊皓然認為,目前有一些開源的框架,重點解決了彈性伸縮的問題,但還沒有廣泛的和其它服務連接,沒有充分發揮的威力。以應用為中心,而不是以資源為中心對于函數計算的實現方式,楊皓然認為立足點應該是以應用為中心,而不是以資源為中心。
摘要: 過去十年,云服務深刻地改變了社會獲取和使用計算能力的方式,云服務自身也以極快的速度演進。在基礎設施云化之后,容器、Serverless等技術迅猛發展,開始推動業務能力的云化,云計算進入2.0時代。
點此查看原文:https://yq.aliyun.com/article...
自2006年AWS發布的第一個云服務S3開始,存儲、計算等IT基礎設施的能力紛紛被以服務的方式提供給用戶。過去十年,云服務深刻地改變了社會獲取和使用計算能力的方式,云服務自身也以極快的速度演進。在基礎設施云化之后,容器、Serverless等技術迅猛發展,開始推動業務能力的云化,云計算進入2.0時代。
12月19日的阿里云棲大會上,阿里云函數計算負責人楊皓然做了主題為“觸摸云端編程之道——利用函數計算快速構建彈性可擴展的云原生應用”的演講,他介紹了Serverless與函數即服務(Function as a Service, FaaS)的關系和價值,演講結束后我們就該話題進一步采訪了他。
云是彈性的、經濟的、高效的
什么是云?楊皓然認為“對用戶而言,云的核心是解決資源彈性、財務成本和開發效率的問題”。IaaS,PaaS,FaaS等不同形態的云服務本質上都是為了解決資源的彈性、成本和效率問題,不同的地方在于解決的問題域、角度和方式。最開始,云1.0時代,基礎設施的云化為用戶提供了和傳統IT環境近乎一致的體驗,讓用戶能把應用無縫遷移到云端。IaaS層服務通過虛擬化等技術大幅提高了資源利用率,而用戶也只需租賃計算資源,不必承擔物理硬件的折舊等成本,相比于用戶維護自有IT基礎設施的方式,IaaS在資源彈性和成本等方面有明顯的優勢。當人人都能獲取所需的計算資源后,如何更高效地管理和使用計算資源則是下一個亟待解決的問題,畢竟,系統配置、故障處理、削峰填谷如何充分利用資源對用戶都是不小的負擔。
在楊皓然看來,不同層次的云服務是在從不同的角度去解決這些問題,大致可分為“以資源為中心”和“以應用為中心”兩類。“以資源為中心”,是指沿著IaaS類服務的思路,進一步優化資源的彈性、成本和效率,例如提供更細粒度規格、更快伸縮時間的計算資源。“以應用為中心”,則是指從應用的架構和開發的角度提供服務,幫助用戶構建能充分利用云端資源的、彈性高可用的應用,例如函數計算這樣的FaaS服務,或者容器編排服務等。
FaaS把云的彈性、經濟和高效優勢發揮到了極致
當越來越多的開發者在云端構建應用時,如何正確設計應用架構、充分發揮云的優勢變得越來越重要,“云端優先”的思想應運而生,這便促使“云原生(Cloud Native)”應用開發的出現。相比于Serverless,云原生應用是一個更寬泛的概念,在IaaS、PaaS與FaaS等不同的云平臺上,都可以構建云原生應用,只不過它們的彈性和敏捷收益不同。”
“如果想要充分地發揮云彈性、經濟和高效的優勢,一開始就去適配這些特點,做架構的設計,那么最終得到的就是云原生應用。”楊皓然說。
在云原生架構中,以函數計算等FaaS服務為中心的Serverless架構越來越流行。楊皓然認為:“FaaS把云的彈性、經濟和高效優勢發揮到了極致,真的做到了使開發者只需要關注業務,而不用去管理底層基礎設施。”FaaS有如下主要優勢,這使它被越來越多人關注:
事件驅動,使得可以與其它服務無縫集成;
由云端全托管,運維高效;
實時彈性伸縮,細粒度的資源計量,按需付費。對于用戶來講,即使應用負載有明顯的波峰波谷,資源使用率也是100%;
簡化的編程模型,用戶專注于單個請求邏輯的開發;
可以做嚴格的運行時隔離和權限管理機制,保障安全;
……
如果要在傳統的IT基礎設施上實現彈性高可用的分布式系統,那么開發者需要去管理一些具體的底層細節,比如要考慮某個函數需要調度到哪臺機器上運行?它是以線程方式還是以進程方式運行?進程崩潰怎么處理?網絡不連通怎么辦?……這些都需要開發者編碼實現。
考慮一下邊緣計算的場景,那么這個問題會顯得更加明顯和嚴重。在邊緣場景中,用戶會面對成百上千的小集群,這些設備分布在各種物理環境中,會遇到網絡條件惡劣、硬件架構類型不相同、通信能力限制等問題,由開發者來進行管理幾乎是不可能的。
“但是實際上,用戶應該從底層系統開發維護這類無差別的工作上脫身,專注于業務的創新,更快地將產品推向市場,更快地迭代改進?!睏铕┤唤忉專骸案鞣N云服務就是把這些底層的東西抽象出來,讓用戶能快速地構建彈性的、低成本的、高可用的系統,而Serverless特別是FaaS在這上邊目前做得最極致?!?/p>
連接是函數計算的核心價值
目前談Serverless必FaaS,但實際上FaaS只是Serverless生態的一部分。楊皓然解釋:“首先Serverless是一個生態,涵蓋了計算、存儲以及更上層的、垂直領域的很多服務。它不是一個新概念,AWS第一個云服務 S3 就是Serverless的存儲服務。其次,Serverless已經無處不在了,云端每年發布的新功能、新服務,超過70%都是Serverless形態。FaaS只是整個Serverless生態的一部分,但是最近幾年,因為FaaS才使得Serverless火起來,被更多人關注?!?/p>
因為FaaS把云中存儲和計算的服務都粘合起來了,幫助用戶快速構建云原生應用。而且FaaS以函數為單位來提供資源,這將云彈性和經濟的優勢發揮到了極致。他舉了一個例子:“以往開發一個應用,可能存儲用到了對象存儲等Serverless服務,但這只是一部分,它只是解決了某一個特定問題。用戶仍然要管理機器等基礎設施,開發運維代價高,而通過FaaS,用戶能快速地整合多種云端服務,開發效率有了質的提高?!?/p>
以開發一個短視頻社交應用為例,移動設備上產生的視頻文件上傳到對象存儲中,觸發函數處理,通過函數計算連接其它服務后,用戶只需專注于函數邏輯的開發,比如抽取元數據、人臉識別等等;并且,在這整個架構中,每個環節都是彈性高可用的。
通過事件驅動的連接,函數計算讓對象存儲、消息中間件服務、CDN等單純的數據存儲、流動、分發服務具備了“可編程”的特性,極大地增加了用戶使用這些服務的靈活性。所以廣泛地連接各類存儲、計算或者垂直領域的服務是函數計算的核心價值。相反,楊皓然認為,目前有一些開源的FaaS框架,重點解決了彈性伸縮的問題,但還沒有廣泛的和其它服務連接,沒有充分發揮FaaS的威力。未來,我們應該能看到開源產品在這一塊的長足進步。
以應用為中心,而不是以資源為中心
對于函數計算的實現方式,楊皓然認為“立足點應該是以應用為中心,而不是以資源為中心”。他舉例說明了這個觀點:“以彈性伸縮為例,‘以資源為中心’的思路,是讓用戶設定一些規則,比如某個機器CPU使用率超過85%就要擴容,這是云1.0時代的方法。而函數計算的模式,它是根據應用層的信息去理解用戶的負載,可以采用各種維度的數據,比如TPS、請求延遲,機器的負載等等,用機器學習等方式去分析數據,做出更智能的資源調度,這屬于‘以應用為中心’。”
同時,“以應用為中心”也要求函數計算要同時具備工具和平臺兩種屬性,既能讓用戶解決小范圍的、離散的問題,也能快速構建復雜應用?!叭绾纹胶夤ぞ吆推脚_兩種屬性,是FaaS獲得廣泛應用的關鍵?!睏铕┤徽f。
面臨的挑戰
雖然比較有影響力的Serverless(FaaS)產品已經發布了幾年,但是現在Serverless或者FaaS技術還處在初期階段,產品形態和邊界還有很多值得探索的地方。楊皓然認為,目前Serverless在技術上有幾個點需要去關注:
以應用為中心,更智能地去理解用戶的應用場景;
用戶體驗方面,在整個生態上有很多東西需要完善,如函數協同、狀態管理和工具鏈等等;
與IoT和邊緣網關的無縫結合。
而另一方面,在面向使用者的時候,Serverless也遇到了很大的挑戰。“用戶的開發調試體驗和傳統方式差異較大,需要一定時間的適應。函數計算簡化了用戶編碼的復雜度,卻對架構能力提出了更高的要求。”楊皓然解釋到,“FaaS為了資源的彈性,在運行環境上有諸多限制,使得以單體架構來構建的復雜系統,要遷移到Serverless的架構上比較困難。”
那么在向Serverless架構遷移時可以怎么做呢?楊皓然認為使用函數計算構建應用和微服務架構的理念是契合的,用戶采用微服務架構,把業務邏輯拆解為細粒度的微服務后,一個個微服務可以實現為對應的函數。 所以說,函數計算是微服務理念的一種重要的實踐方式,二者是相互促進的。因此更現實的方式是使用函數計算先解決獨立的、離散的問題,或者采用微服務的方式把系統拆分為細粒度的服務,然后逐步演進到Serverless架構。
從云走向邊緣
目前有一個觀點是“云計算的未來將是走向邊緣”,也就是說以類似于CDN的方式,將計算放到更加靠近用戶的區域。楊皓然說他認同這個觀點,他解釋到:“未來數據的產生將無處不在,并且這些數據需要被處理、被理解,才能產生價值。”從這個角度來看,數據是需要被提煉的,在無處不在的數據中,其實有大量的噪音;而用戶端到云之間有一個通道問題,如果不在貼近數據源端去做一些計算,那么整個帶寬、延遲之類的成本會很不友好。
以IoT為例,楊皓然認為在IoT場景上邊緣計算會特別重要。IoT大量的設備,它的數據量遠遠超過人產生的數據。這種場景下,如何幫助用戶解決數據的收集和分析問題將非常重要,也非常有挑戰。IoT/邊緣環境是非常獨特的,硬件架構迥異(ARM、X86、MIPS……)、通信協議眾多、設備動態加入/刪除、網絡并不總是可用等等,面對這樣的環境,需要以全新的方式構建應用。楊皓然總結了理想的邊緣環境計算平臺,需要具備的一些特點:
IoT的數據處理一定會發生在邊緣和云端,因此應用也一定包含邊緣和云端兩部分,二者需要以統一的方式構建,數據能在邊緣和云端無縫同步;
IoT 的環境是動態的,設備/網絡可以很自由的加入/刪除。幾乎所有的協議設計都是事件驅動的方式,例如發布/訂閱模式;
IoT 在邊緣上的應用,通常是輕量的,因此設備/資源/安全管理層的研發成本不能被應用邏輯的開發成本分攤掉。需要有更高的計算抽象層次,讓開發專注于業務邏輯。
函數計算這樣的全托管事件驅動服務比較符合上述要求,目前我們也看到業界在這上面的一些探索,相信未來FaaS在邊緣環境也會發揮重要的作用。
FaaS已經在云2.0時代發揮了它的優勢,至于它之后將走向何方,又將創造怎樣的輝煌,我們拭目以待。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/11818.html
摘要:導讀近期靈雀云技術專家邵明岐翻譯了所著的一書的部分內容,可以說是對科普與觀察的上佳素材。的另一半是是的另一種形式,概念上容易混淆的地方在于,有時候將自己的服務,,稱為。 導讀:近期靈雀云技術專家邵明岐翻譯了Mike Roberts & John Chapin所著的《What is serverless》一書的部分內容,可以說是對Serverless科普與觀察的上佳素材。本文為第1篇,他...
摘要:目前,網易云輕舟微服務平臺已經應用于銀行證券視頻監控物流工業等行業不少中大型企業,幫助其實施微服務化改造,建設符合行業特點的業務中臺,支撐企業數字化戰略的落地。 微服務技術由于天生支持快速迭代、彈性擴展的特點,使企業能夠在不確定性下提升發展速度及抗風險能力,受到了越來越多的關注。當前,云服務商紛紛試水微服務產品,最為典型的,當屬推出輕舟微服務平臺、劍指整個微服務應用生命周期的網易云。 ...
摘要:據預測,到年,大多數的企業應用將被遷移到云中。在云計算的霧期更需要對云計算產業有一個清醒的認識,不要在最后隨著霧散去自己也隨霧而去。 從概念開始逐漸轉為應用落地,各企業紛紛加入到云計算浪潮,國家也在大力扶植云計算產業。據預測,到2020年,大多數的企業應用將被遷移到云中。與此同時,越來越多的應用開發商也將把應用開發、測試平臺遷移到云中。 專家表示,以云計算為代表的新型計算機模式未來將成...
摘要:梁雅莉表示英特爾是一家以數據為中心的,領先的創新者。我們將一如既往,持續推動包括云計算在內的技術創新,加深與合作伙伴協作,讓云服務可以更快更好更高效的飛入尋常百姓家。今天,當人們談到云計算時,都顯得格外從容。因為,在過去的十多年中,云計算在全球逐漸從概念走向落地和實踐。云計算技術變得更加成熟,產業鏈變得更加完善,市場規模也在不斷擴大。據Gartner 2017年的研究報告預計,全球云計算市場...
閱讀 1816·2019-08-30 13:54
閱讀 2730·2019-08-29 17:27
閱讀 1116·2019-08-29 17:23
閱讀 3355·2019-08-29 15:20
閱讀 1231·2019-08-29 11:28
閱讀 1575·2019-08-26 10:39
閱讀 1321·2019-08-26 10:29
閱讀 646·2019-08-26 10:13