1.前端變革史前端
2.Serverless-從前端到全棧git
3.騰訊云云開發對Serverless的落地實踐github
4.開發生態web
5.場景多樣化支撐數據庫
----------------------------------------------------------------------------------------------編程
若是要探討一項技術或者一種理念是否具備革命性,必然須要參照物,歷史是最佳的 參考。因此在討論Serverless對前端的革新以前,有必要先「飛快」地回憶一下前端變革史。
若是以世界上第一個web瀏覽器WorldWideWeb的誕生做爲起點,那麼90年代初即是前端的0.0時代。彼時沒有前端工程師的稱謂,前端的工做也很簡單,主要是靜態UI和表單驗證,要麼後端工程師兼顧爲之,要麼由獨立的UI Developer全權負責。小程序
其實時至今日不少外企仍然沿襲着UI Developer崗位,與目前大衆認知的前端工程師不一樣的是,UI Developer的能力棧除了HTML/JS/CSS之外,還要具有必定的UI和交互設計能力。windows
起源於Microsoft Outlook的AJAX是引發前端第一次革命的關鍵技術,這是一個重要的轉折點,以此爲契機網站具有了動態性,前端工程師的能力模型逐漸從UI偏向邏輯和數據。後端
而後是廣爲人知的Node.js成就了前端2.0。Node.js破除了先後端編程語言的壁壘,令前端開發者可以以相對較小的成本跨界服務端,可是編程語言僅僅是服務端開發最表層也是最易突破的,背後更困難的部分是單純靠Node.js沒法解決的,細節稍後再表。除了服務端之外,Node.js對前端最大的貢獻是提供了工程化的土壤。瀏覽器
在此各位不妨思考一個問題:一個構建工具最基本最底層的能力是什麼?答案是文件IO。
在Node.js以前,HTML/JS/CSS的構建只有兩個途徑。第一是藉助其餘編程語言的工具,好比YUI Compressor;第二是用IE瀏覽器。這不是笑話,IE瀏覽器可以在早期佔據霸主地位可不徹底是由於windows系統的背書,它自身的功能性也很是強大。衆所周知早期的IE瀏覽器是windows系統的一個組件,以它爲入口能夠調用一些系統級的底層功能,文件IO便在此列,實現的方式是藉助ActiveX控件的FileSystemObject對象。細節就不講了,感興趣的同窗能夠自行參閱相關資料。
有一些聲音認爲React可以配得上「革命性」一詞,由於它必定程度上改變了前端的編程模型,React以前的前端是圍繞DOM,React以後是面向數據。誠然如此,但跟AJAX和Node.js相比,React引發的變革仍顯輕微。而React對前端組件化生態的影響也是在原有基礎上的加強也並不能稱爲革命性。因此稱React爲前端3.0缺少足夠的說服力,不過前端2.5仍是充分的。說到底,React只是改變了前端領域自身,而AJAX和Node.js無一不是對先後端都有顯著影響的技術。
在討論哪項技術或理念會成就前端3.0以前,必需要確認前端下一步的發展方向。
目前有兩種聲音:一是先後端包攬的「大前端」,也就是全棧,關鍵性技術是Node.js;二是以React-Native和Flutter爲突破點的「泛前端」,即全端。
以目前的時間節點來看,React-Native也好,Flutter也罷,都還未可以稱得上成熟,泛前端之路任重道遠。相對來講,前端下一步發展爲全棧的可能性更高一些。基於這個前提,Serverless即是成就此道的革命性技術理念。
「全棧」這個詞其實一直存在歧義,狹義上的全棧來源於前端技術圈,指的是一我的包攬前端和web服務端;而廣義上的全棧應該是在先後端之外還包括數據庫而且可以精通圍繞三者展開的架構和技術細節,這是幾乎不可能的任務,若是真的有人可以達到這種境界,估計就是接近艾倫·圖靈通常的計算機之神了吧。在狹義與廣義之間,Serverless面向的是廣義的全棧。
Serverless的理念是將服務器管理、數據庫優化等「粗活」交給雲平臺,從而前端開發者可以將交互邏輯、業務邏輯、數據所有掌控在本身手中,這纔是真正意義上的全棧。
爲了可以更清晰地理解Serverless,有一種架構模式能夠做爲對比,即BFF(Backends for Frontend,爲前端服務的後端)。
BFF-從平臺無關性到平臺差別化
BFF簡單來講就是在原有的一體化服務端基礎上,針對不一樣的業務平臺分別開發一層獨有的、很薄的服務,見下圖。
BFF承擔了一部分的業務邏輯,這部分邏輯一般是平臺獨有的。舉一個現實中的例子:在線視頻提供商有多種平臺,好比網站、app。因爲版權限制有些影片只能在特定的平臺播放。具化到技術層面,實現此類邏輯包含分平臺鑑權、數據查詢策略等等,這些即是典型的平臺差別化業務邏輯。獨立於核心業務邏輯以外的BFF層可以實現差別化邏輯的鬆耦合,進而令迭代和維護更高效和安全。
BFF未解決的問題
目前業內對BFF廣泛實踐模式是將BFF分發到負責各平臺技術開發的團隊,好比App團隊負責Mobile BFF、前端團隊負責PC web和H5 BFF等等。那麼對於前端工程師來講,這種模式是否意味着前端兼顧BFF層?理想的場景是這樣的,但現實工做中並不是如此。
BFF本質上仍然是服務層,除了編程語言以外,一名合格的服務端開發者還須要具有一些獨有的領域知識以及服務管理、數據管理理念。因此目前大多數BFF仍然由傳統前端以外的專人負責,即使是Node.js BFF。
也就是說,BFF並未解決前端成爲全棧的關鍵性問題,而這些問題即是Serverless的針對點。
騰訊雲 雲開發對Serverless的落地實踐
目前業內對於Serverless的廣泛認知是FaaS(Function as a service,函數即服務)和BaaS(Backend as a service,後端即服務)的綜合體。以此爲前提,騰訊雲的相關團隊將Serverless的具體實現爲下圖所示的模型。
以此爲支撐,落地到具體應用場景中的雲開發模式以下圖:
各平臺應用的前端集成對應的SDK,涵蓋雲函數、雲數據庫和雲存儲的功能調用API。前端的請求直接送達雲平臺的接入層,目前是以Node.js做爲接入層技術棧;而後通過必要的處理(好比用戶鑑權)轉至雲函數、雲數據庫以及雲存儲平臺。
以雲開發體系提供的功能和服務爲基礎支撐,前端開發者的關注點除了UI和交互邏輯之外,可以以很小的成本介入以雲函數爲承載的業務邏輯層和以雲數據庫、雲存儲爲支撐的數據存儲層。簡而言之,前端的關注點爲:交互邏輯+業務邏輯(雲函數)+數據(雲數據庫/雲存儲)。
從上文的描述中可能有部分同窗意識到一個問題:雲存儲跟CDN有什麼區別?
雲存儲提供文件託管服務,本質上與CDN相同。其優點體如今開發者無需申請域名、無需管理服務器,文件被自動託管,而且能夠經過鑑權機制保證文件的私密性和安全性。其實針對CDN的話題能夠延伸到Serverless,大多數前端開發者在工做中都無需關係CDN服務器的狀態,只須要部署文件便可(甚至這一步也能夠由CI系統完成),那麼CDN對於前端開發者來講就能夠被認爲是Serverless的。
完整的Serverless體系不只僅包括CDN,還能夠把數據庫和服務端也實現Serverless。在這套體系支撐下的工程模型中,一個完整的迭代週期僅僅須要兩種職能角色:前端和測試。前端負責全部與業務相關的工做,包括交互層、業務層和數據層;測試負責質量保證;而部署、發佈、服務器管理、線上監控等等繁瑣的工做則交由雲開發平臺去完成。
在以上雲開發模式基礎上,具體到現實上手開發,開發者們須要瞭解三種角色:端、雲和控制檯。
- 端的表現形式是對應各平臺的SDK,是與前端開發者關係最緊密的一個角色;
- 雲指的是支撐Serverless體系的後臺系統,這部分對於開發者來講是無感知的,與其對接的工做由端SDK承擔。細化到子角色能夠分爲接入層和基礎服務,接入層負責代理轉發和用戶鑑權等工做;基礎服務提供基本的能力支撐,包括雲函數、雲數據庫和雲存儲;
- 控制檯的功能分爲兩大類:一是管理功能,好比雲函數的部署、數據和文件的管理等等;二是運營,控制檯提供產品線上監控以及數據的統計和可視化,以輔助運營。
任何一種新技術或者架構落地到具體的業務場景中都不免會遇到因爲業務特殊性形成的遷移困難問題,因此在基礎的開發生態以外,雲開發爲支撐多樣化的業務場景創建了必要的策略以及對應的工具。
好比對於數據私密性存在高要求的產品,能夠經過控制檯選擇嚴格的CURD權限管理策略;而且可使用wx-service-sdk在雲函數中進行私密數據的CURD以保障安全性;再好比對實時性要求較高的場景,好比在線客服、多人遊戲等,雲數據庫的實時推送功能能夠保障此類功能的高效表現。
Serverless以雲計算相關技術爲支撐,搭配容器技術和微服務架構,將基礎實施的管理從開發者平常工做中解耦。雖然目前不管是理論解讀仍是實踐模式都還沒有造成絕對統一,但能夠預見前端開發者將成爲Serverless的最大受益羣體之一,咱們有充足的理由相信它將引起前端的第三次變革。
更多精彩文章可關注公衆號【騰訊云云開發】。
目前正在開展0基礎10天入門小程序開發的免費活動,關注公衆號回覆【訓練營】便可參與學習。
https://cloud.tencent.com/edu/learning/live-1568?ADTAG=ds.in
課程源碼地址:https://github.com/Juliiii/scf-task-list
Serverless——前端的3.0時代 - 騰訊云云開發的文章 - 知乎 https://zhuanlan.zhihu.com/p/84054729