一般情況下,開發一個系統都需要前端和後端,僅靠一個人幾乎無法勝任,需要考慮的特性和功能非常多,比如:
這對於沒有後端基礎的同學來說,簡直是個噩夢!
那麼是否存在一種新模式,可以讓開發者只專注於業務呢?
目前解決這個問題最主流的方案就是 Serverless 架構,也就是所謂的無伺服器計算。開發者只需要專注於程式碼質量和程式碼邏輯,不需要關心基礎設施,也不需要關心後端服務,一切都由平臺給你自動分配資源。
但這個平臺從哪來?
畢竟 Serverless 只是一個架構和抽象理念,要想落地,還得實現一個真正的產品。
這樣的產品其實國內有很多,也就是所謂的雲開發服務。這一類服務將開發一個完整的應用需要用到的資料庫、儲存、CDN、後端函數、靜態託管、使用者登入等等功能全部整合到了一起,研發人員僅需要呼叫這些服務即可。
目前,雲端計算和整個網際網路市場正逐漸從增量市場轉向存量市場,營收和淨利潤才是 KPI ,在這個背景下,降低成本和提高利潤至關重要。基於開源的雲端計算生態逐漸崛起,為市場提供了更具競爭力的選擇,每家企業都可以擺脫供應商鎖定自由到處執行,無需擔心供應商的倒閉、產品下線或價格上漲等問題。最糟糕的情況下,企業甚至可以自行部署一套系統,並針對自身需求客製化一些高階功能。
Laf 就是這樣一個完全開源的雲開發平臺。
它提供了開箱即用的雲函數,雲資料庫,物件儲存等能力,是一個一站式開發平臺,讓你可以像寫部落格一樣寫程式碼。
與各大雲廠商的雲開發平臺相比,Laf 也不遑多讓,而且還有很多雲廠商不具備的核心優勢:
除此之外,Laf 還提供了很多額外的優秀能力:
還有個非常重要的一點就是 Laf 是執行在 Sealos 雲作業系統之上的,所有的擴充套件工作都可以在 Sealos 雲作業系統中進行,例如在 Sealos 上執行 AI 引擎並通過 Laf 進行呼叫,實現完美融合。
GitHub 連結:https://github.com/labring/laf
Laf 自去年 11 月份釋出 0.8 版本以來,使用者數量一直都在不斷上漲,預覽版本短短几天就吸引 2000+ 註冊使用者,支撐 3000+ 線上應用。到如今 Star 數量已經突破了 3.5k。
期間有很多優秀的開發者基於 Laf 開發出了很多有趣的產品,比如:
除此之外,還可以用 Laf 來開發各種管理系統和電商應用,甚至區塊鏈應用。我們的企業級客戶聚道雲就選擇了將 Laf 託管在專有叢集中,利用 Laf 為其提供函數計算解決方案。總的來說,Laf 的適用場景非常廣泛,大到企業官網和資訊化建設,小到個人部落格、微信小程式,理論上可以開發任何應用!
今天我們正式釋出了 1.0 版本,這是 Laf 的一個里程碑版本,帶來了很多重量級的更新。視覺化介面煥然一新,優化了使用者操作流程和互動設計,進一步提升了使用者體驗,從建立應用到上線第一個函數僅需 1 分鐘。
Laf v1.0 的釋出,離不開各位社群小夥伴的悉心貢獻與鼎力支援,無論是功能研發、功能測試、需求建議、企業最佳實踐,抑或是提供 Bug 修復、國際化翻譯以及檔案貢獻,這些來自開源社群的貢獻都為 v1.0 的釋出和推廣提供了極大的幫助,我們將在文末向這些小夥伴予以特別緻謝!
為了提高開發者的開發效率,Laf 提供了一種視覺化的函數介面,讓開發者可以在不離開平臺的情況下進行程式碼編寫、偵錯和部署,從而快速實現業務需求。這樣開發者可以更加專注於程式碼邏輯和質量,在同一平臺上完成所有工作,而無需切換到其他工具和平臺,從而大大提高了開發效率。
隨著 Vue3 的釋出,許多前端專案需要進行從 Vue2 到 Vue3 的升級。然而,在 UI 元件庫方面,Vue的可選項較少。相比之下,React 的 UI 元件庫更加豐富和成熟。
因此,Laf v1.0 選擇了 React 作為主要技術棧,包括 Chakra-UI、Tailwind 和 React-Query,這些技術棧可以幫助開發者更加高效地構建使用者介面。例如,Chakra-UI 提供了豐富的 UI 元件庫,Tailwind 提供了可客製化化的 CSS 樣式,React-Query 則提供了資料管理和快取等實用功能。
Laf v1.0 仍然使用 TypeScript 作為開發語言,以及 Vite 作為構建工具,大大提高了開發效率和 UI 客製化化的便利性。而且函數介面增加了動態佈局,可以隨意拖動或隱藏相關面板。
與 v0.8 相比,v1.0 還新增了請求方法設定,可以設定函數的請求型別,例如 GET/POST 等等,同時還支援 Params、Body 以及 Headers 的偵錯引數。
除此之外,還優化了集合頁面的展示,可以一站式完成資料管理、存取策略等功能,大大提高了開發效率。
隨著開發效率的提高,很多應用的開發週期甚至可以壓縮為分鐘級,且具有高度複用性,如各種三分鐘系列:
這裡並非編寫一個僅供娛樂的範例,而是真正具備線上服務能力。最重要的是,這三分鐘並非僅編寫程式碼,還包括將程式碼線上上執行!寫完即釋出,點選儲存,關機走人。
在 Laf 0.8 版本中,我們使用 Express 進行開發。然而,在專案規模逐漸增大的情況下,維護和共同作業方面會面臨一些挑戰。因此,Laf v1.0 便遷移到了 NestJS。由於 NestJS 支援 TypeScript,因此具有更好的型別安全性和編譯時錯誤檢查等優點。此外,NestJS 的模組化開發風格使得專案結構更加清晰,易於維護。
NestJS 還提供了許多實用功能,如內建的 Swagger 檔案生成器。這個生成器可以根據程式碼自動生成 API 檔案,使得前後端共同作業更加順暢和高效。
在 Laf v1.0 中,ORM 框架選擇了 Prisma。Prisma 是一種現代的 ORM 框架,提供了強大的資料建模和查詢功能,同時也具有更好的可維護性。通過使用 Prisma,Laf 可以更加高效地運算元據庫,簡化資料管理和維護過程。
除了上述更新之外,Laf v1.0 還對核心功能進行了重構,主要包括以下兩個方面:
1️⃣ 對 Node Runtime 進行了升級,剝離了原先內建的 WebSocket 模組,改成統一的 Cron 模式。這種模式使得 Runtime 更加輕量,同時也提高了程式執行的穩定性和可靠性。
2️⃣ 對資料庫的使用者介面和互動進行了優化,通過簡化介面設計和增強使用者互動性,我們省去了繁瑣的二級乃至三級頁面,不管是新手還是老手都能夠更加高效地完成資料的查詢、修改和管理等操作。
3️⃣ 雲端儲存方面,在儲存檔案的基礎上,我們還增加了靜態網站託管,釋出之後直接分配一個二級域名上線(同時支援自定義域名),無需關心複雜的 CI/CD、Docker 或 K8s 等技術,有了 Laf 老夫只需要一把梭,真正的涵蓋從開發到上線的所有步驟,正如我們口號所說 life is short you need laf ,開發者應該把時間節省下來關注更重要的事情。
4️⃣ 支援 ESM 模組的引入。開發者可以引入一些只支援 ESM 的 NPM 包,例如 ChatGPT 等。這大大增加了應用程式的可延伸性和功能性。同時,ESM 還支援模組級別的作用域,這使得程式碼更加清晰、易於維護。
例如,可以在函數介面引入著名的 chatgpt-api NPM 包。首先在 NPM 依賴面板中點選右上角的 +
:
然後輸入 chatgpt 並回車進行搜尋,選擇第一個搜尋結果,儲存並重啟:
重啟之後,自定義依賴項中便出現了 chatgpt。
現在我們來試試呼叫 ChatGPT 的 API 來與 ChatGPT 進行對話,先寫個函數:
import cloud from '@lafjs/cloud'
export async function main(ctx: FunctionContext) {
const { ChatGPTAPI } = await import('chatgpt')
const api = new ChatGPTAPI({ apiKey: cloud.env.CHAT_GPT_API_KEY })
let res = await api.sendMessage('「雞你太美」指的是中國大陸哪位男藝人?給你個提示,他喜歡唱、跳、籃球、Rap')
console.log(res.text)
return res.text
}
將上述函數程式碼新增到 WebIDE 中,點選右上角的「執行」,即可偵錯執行。
Laf 的應用開發上線週期極短,基本上都是以分鐘/小時/天來計算的。恰逢 AI 崛起,每天關於 AI 的資訊目不暇接,今天的資訊還沒消化完,明天又有新的來襲。可以預見,未來 AI 應用一定會爆炸式增長,很多傳統的方式都將會被徹底顛覆。在這個浪潮中,必然會有很多新的 AI 應用需要被開發出來,而選擇使用函數計算來開發 AI 應用的公司必然在競爭中勝出,因為在這個浪潮中兵貴神速。使用函數計算可以按照分鐘或小時來計算開發進度,而傳統的公司可能仍在緩慢地進行迭代和上線,必然會在競爭中落後。
所以接下來 Laf 將會重點聚焦於如何讓 AI 能力快速落地,快速開發各種 AI 小應用,打造 AI 能力生態,幫助 AI 浪潮下的企業在競爭中快速勝出。
以下是參與 Laf 1.0 程式碼和檔案貢獻的貢獻者 GitHub ID。如果名單中有遺漏,請您與我們聯絡。名單中的排名並無先後之分。
歡迎對 Laf 感興趣的小夥伴加入我們的微信交流群,入群方式:新增 wx 好友 cloud-native-yang,然後傳送暗號 laf 即可入群。
我們還開通了中文論壇,旨在讓各位社群小夥伴共同探討 Laf 及相關技術之研究、使用技巧之分享,及對遇到問題者之援助。歡迎來泡吧!!