1. 程式人生 > 其它 >即學即會 Serverless | 如何解決 Serverless 應用開發部署的難題?

即學即會 Serverless | 如何解決 Serverless 應用開發部署的難題?

本文節選自《Serverless 開發速查手冊》,關注Serverless 公眾回覆 手冊 即可獲得下載連結

作者 | 江昱(阿里雲 Serverless 產品經理)

破局:工具鏈體系匱乏之困

在前篇《即學即會 Serverless | 初識 Serverless》一文中,我們提到 Serverless 正在改變未來軟體開發的模式和流程,並被預測將引領雲端計算的下一個十年,但儘管如此,開發者在選擇使用 Serverless 時仍有諸多擔憂,這其中最受關注的無疑就是工具鏈體系的匱乏。

所謂工具鏈的匱乏:一方面表現在市面上工具鏈不完善,這導致開發和部署難度大,進而增加成本;另一方面表現在,缺乏相關的工具鏈在體驗層將 Serverless 體驗進一步規範,優質工具鏈的匱乏導致本來就擔心被廠商繫結的 Serverless 開發者變得更難與廠商解綁。

2020 年 10 月,中國資訊通訊研究院釋出國內首個《雲原生使用者調查報告》明確指出在使用 Serverless 架構之前,49% 的使用者考慮部署成本,26% 的使用者考慮廠商繫結情況,24% 的使用者考慮相關工具及完善程度,這些資料背後透露的實際上是:開發者對於完善工具鏈的強烈需求。

儘管,有一些開發者認為入門 Serverless 架構,通過白屏化的操作相對來說會更容易入門,在一定程度上通過各個雲廠商的控制檯進行函式的建立、更新,也會更加地方便。但是不可否定的是,Serverless 開發者工具在一定程度上其實有著更為重要的價值和作用,譬如:

  • 通過腳手架,能夠快速建立 Serverless 架構的應用;
  • 在開發過程中,通過開發者工具可以進行應用的除錯等;
  • 在開發完成之後,通過開發者工具能夠將應用一鍵部署到線上(可能包括多個函式以及相對應的 BaaS 類產品);
  • 專案運維階段,使用開發者工具進行專案的可觀測以及問題定位等;

若需要實現科學部署,通過某些 CI/CD 平臺/工具釋出 Serverless 架構的應用,通常是離不開開發者工具的;但是就目前來看,Serverless 領域的開發者工具複雜多樣,且諸多功能並不完善,基本表現在:

並沒有絕對統一 & 一致的 Serverless 開發者工具,每個廠商都有自己的開發者工具,而且使用形式、行為表現並不相同,這就導致了開發者在開發前的調研、開發中的除錯、部署後的運維等多個層面面臨很嚴峻的挑戰;

絕大部分的 Serverless 開發者工具更多是資源編排、部署工具,並不能真正意義上稱之為開發工具、運維工具,尤其在開發態的除錯如何保證線上線下環境的一致性;

如何在運維態可以快速的對業務進行除錯;如何更簡單的排查錯誤,定位問題......等方面並沒有統一的、完整的方案,這就導致 Serverless 架構的學習成本、使用成本對開發者來說會變的非常高;

綜上所述,出現一個可以提升 Serverless 應用開發效能,降低 Serverless 架構使用難度的 Serverless 工具鏈體系建設,顯得尤為重要,也正是因為此,Serverless Devs 應運而生。

Serverless Devs 是一個開源開放的 Serverless 開發者平臺,致力於為開發者提供強大的工具鏈體系。通過該平臺,各位開發者不僅可以一鍵體驗多雲 Serverless 產品,極速部署 Serverless 專案,還可以在 Serverless 應用全生命週期進行專案的管理,能夠非常簡單快速的將 Serverless Devs 與其他工具/平臺進行結合,進一步提升研發、運維效能。

Serverless Devs 的特點

無廠商鎖定:得益於功能的可插拔特性,可以非常簡單的支援不同雲廠商的專案部署,或者一鍵部署到不同雲平臺。目前 Serverless Devs 已經支援了阿里雲函式計算、AWS Lambda 、百度智慧雲函式計算 、華為雲函式工作流 、騰訊云云函式等多雲的 FaaS 產品;

開源形式建設:專案通過開原始碼,開放生態進行建設,開發者可以隨時檢視和參與 Serverless Devs 開發者工具的貢獻,也可以隨時隨地進行相關元件和應用的貢獻。當然,除了這種開源開放的形態,我們也鼓勵一些企業級團隊,通過 Serverless Registry Model 建設自己的私有 Registry 以定製化某些不便公開的自定義元件;

關於如何快速完成 Serverless Devs 應用開發併發布到 Regsitry 可查閱相關文件:
https://github.com/Serverless-Devs/Serverless-Devs/discussions/439

簡單快速上手:通過開放 Serverless Registry 的模型/規範,該專案可以通過應用的模式,為開發者提供多種形式,多種領域以及多種場景的上手案例,幫助開發者快速瞭解、學習、深入、上手 Serverless 架構,例如新手引導中的 Serverless:Hello World;人工智慧:目標檢測;傳統框架:基於 Django 的部落格專案等專案;

場景體驗地址:
https://developer.aliyun.com/adc/expo/serverless

功能靈活可插拔:Serverless Devs 開發者工具本身,不具備任何業務能力,所有的業務能力均是通過元件化的形式,進行可插拔式使用,並且每個元件可以根據需要,自定義相對應的命令和功能;開發者可以在一個應用中,選擇不同的元件完成對應的業務能力,以滿足對不同模組的訴求;

應用全生命週期管理:通過元件化的支援,Serverless Devs 可以在應用的全生命週期發揮重要作用,以阿里雲函式計算的 FC 元件為例,開發者可以在專案建立、專案的開發、除錯、可觀測性等多個層面進行專案的建設和管理;

良好的整合與被整合性:專案具有非常好的整合性與被整合性,可以通過元件化的支援,非常簡單的與傳統的生態進行有機結合。同時,Serverless Devs 開發者工具也可以非常簡單的被整合到海量的自動化流程中,例如 CI/CD 文件中,就舉例了與 Github Action 的整合、與 Gitee Go 的整合、與 Jenkins 的整合等平臺整合的案例;

總的來說,Serverless Devs 是一個開源開發的 Serverless 領域的工具鏈專案,它不僅僅表示單純的某個命令列工具,更在一定程度上指的是一個完整的工具鏈體系。

社群網址一覽(可滑動):

社群官網:http://www.serverless-devs.com/

專案倉庫:https://github.com/Serverless-Devs/Serverless-DevsServerlessDesktop

桌面客戶端:https://serverlessdevs.resume.net.cn/zh-cn/desktop/index.htmlServerless

應用開發者套件:http://serverless-dk.oss.devsapp.net/docs/tutorialdk/intro/react

Serverless Devs CLI:https://serverlessdevs.resume.net.cn/zh-cn/cli/index.html

Serverless Hub應用中心 :https://serverlesshub.resume.net.cn/#/hubs/special-view

Serverless Devs 的成長之路

  • 2020年10月23日,Serverless 開發者平臺 Serverless Devs 正式開源;
  • 2020年11月,Serverless Devs 被 CNCF Landsacpe 收錄, 成為國內首個進駐的 Serverless 工具;
  • 2020年11月,入圍 InfoQ 評選 2020 年度十大開源新銳專案;同年,Serverless Developer Meetup 首召開,成 Serverless 開發者技術新渠道;
  • 2020年12月,ServerlessDevs 下載次數突破 5000,元件 & 應用累計使用次數突破 1w+;
  • 2021年4月,Serverless Developer Meetup 在上海召開,並正式釋出 Serverless Devs 2.0 版本;
  • 2021年7月,Serverless Developer Meetup 在杭州召開,阿里雲函式計算團隊在會上正式釋出端雲聯調、桌面客戶端等功能;
  • 2021年8月,Serverless Devs 下載次數突破 2w+;
  • 2021年10月,在 2021 OpenInfra Days China 會議上,Serverless Devs 帶來了《Serverless Devs:Serverless 全生命週期的工具鏈建設》的主題演講;
  • 2021年12月,Serverless Developer Meetup 在深圳召開,並嘗試性的對外展示了 Serverless Devs Model;

Serverless Devs 的設計哲學

Serverless Devs 的模型設計原則,是希望可以通過更加簡單、科學、規範的 Serverless 工具鏈體系,讓開發者更專注於業務邏輯,提升 Serverless 應用開發、部署、運維效率。

通過該模型,開發者可以通過一種更靈活、更通用的方法使用不同雲廠商以及開源的 Serverless 產品,進而更高效、更簡潔、更便利的實現 Serverless 應用管理。在 Serverless Devs 中,通常擁有兩個角色:

開源貢獻者:開源貢獻者將按照 Serverless Package Model 進行元件/應用的開發,並將內容釋出到 Serverless Hub 中,即可以被更多人所使用;

Serverless 開發者:通過開發者工具 (包括命令列工具以及桌面端等工具),進行應用的初始化,以及元件的使用;通過開發者工具,將業務按照預期部署到線上。

在這樣一個 Serverless Devs 的應用框架上,不難發現可以和其他任何一種模式/生態,具有相似的命名以及模組:

Serverless Hub:類似於一種元件、應用、案例中心;類似於 Docker Hub 等;

Serverless Registry:類似於一種元件、應用的管理工具或者規範模型;類似於 Python 生態中的 Pypi,類似於 Node.js 生態中的 NPM;

下面我們再詳細地介紹一下,在 Serverless Hub 中,其實是有兩種形態的 Package (元件和應用),同時通過上圖也可以看到兩個比較明顯的詞彙:Component 和 Application:

  • Component:指的是元件;是由 Package developer 開發併發布的符合 Serverless Package Model 規範的一段程式碼,通常這段程式碼會在應用中被引用,並在 Serverless Devs 開發者工具中被載入,並按照預定的規則進行執行某些動作。例如,將使用者的程式碼部署到 Serverless 平臺;將 Serverless 應用進行構建和打包;對 Serverless 應用進行除錯等;

  • Application:指的是應用,可以由 Package Developer 公開發布到 Registry,以供更多人學習和使用,例如某位貢獻者貢獻了一個貓狗識別的案例到 Registry;也可以由 Serverless Developer 開發,例如某人開發了一個人臉識別的應用;通常情況下一個應用可以引用一個或者多個元件,並通過 Serverless Devs 開發者工具部署到 Serverless 平臺,例如我開發了一個貓狗識別的應用,在這個應用中引用了 Lambda 元件幫助我將部分業務邏輯部署到 FaaS 平臺,同時我也引用了 Website 元件幫助我把前端業務程式碼部署到物件儲存中。

如果說 Serverless 提升了傳統應用的開發效能,那麼 Serverless Devs 開發者工具就是提升了 Serverless 應用開發的效能。隨著時間的發展,Serverless Devs 也從 1.0 版本 到了 2.0 版本。

結語

本篇介紹了 Serverless Devs 的前世今生,實際上,我們一直希望可以通過 Serverless Devs 的工具鏈模式和思路,讓各位通過該平臺能夠一鍵體驗多雲 Serverless 產品,極速部署 Serverless 專案;為應用的開發,傳統專案上 Serverless 架構提供巨大的便利和更科學的管理。在下篇文章中,我們會帶領各位一起實現 Serverless Devs 的基礎入門,十分簡單,並會就一些功能案例進行刨析解讀,歡迎關注 Serverless 公眾號(serverlessdevs)連續訂閱該系列。

更多內容關注 Serverless 微信公眾號(ID:serverlessdevs),彙集 Serverless 技術最全內容,定期舉辦 Serverless 活動、直播,使用者最佳實踐。