進階
Serverless 輸出格式

Serverless 輸出格式

Zeabur 同時支援容器化(Containerized)和 Serverless 兩種部署方式,當你把專案的程式碼部署到 Zeabur 後,Zeabur 會使用 zbpack (opens in a new tab) 進行自動化的分析和構建,相關的流程說明可以在 構建原理 中找到。

容器化的部署方式需要消耗較多的計算資源,因為即使服務沒有被使用,他也需要保持開啟狀態以便維持服務內部的各種狀態。而 Serverless 的部署方式則是將服務拆解為多個即開即用的 Serverless 函數,當服務接收到外部請求以後,執行函數來計算並返回結果,因此提供了更高的擴展性且節省了不必要的成本。

構建產出格式

在沒有任何額外設定的情況下,zbpack 會基於專案所使用的開發框架來選擇是否要使用 Serverless 的方式進行構建。如果 zbpack 決定使用 Serverless 方式進行構建,則構建完成以後可以在專案目錄下找到 .zeabur/output 目錄,該目錄下的結構如下:

.zeabur/output
├── static
│   ├── index.html
│   └── ...
├── functions
│   ├── index.func
│   └── ...

其中 static 目錄下存放的是靜態資源,例如 HTML、CSS、JavaScript 等,而 functions 目錄下存放的是 Serverless 函數,每個以 .func 結尾的目錄都是一個函數入口,他們對應了服務部署上線後的一個路徑,例如:

  • functions/index.func 對應的路徑是 /
  • functions/users/get.func 對應的路徑是 /users/get
  • functions/api/orders.func 對應的路徑是 /api/orders
  • functions/api/orders/[id].func 對應的路徑是 /api/orders/[id],其中 [id] 是一個動態路徑,可以匹配任意的路徑。

為了最大化構建產物的相容性,zbpack 的 Serverless 構建產物格式盡可能地與 Vercel (opens in a new tab)Build Output API (v3) (opens in a new tab) 保持一致。如此一來,現有的框架或未來新出的框架的作者及團隊就不需要重新為各個不同的平台開發適配器(Adapter)了。

純靜態輸出

對於基於純靜態的網站框架,例如 Vite (opens in a new tab) 等等,在 zbpack 構建完的 .zeabur/output 目錄下,只會有 static 目錄,而沒有 functions 目錄,這是因為純靜態的網站框架不需要使用 Serverless 的方式進行部署,因此 zbpack 會直接將所有的靜態資源打包到 static 目錄下,並且在部署的時候直接將 static 目錄下的資源部署到 CDN 上。

Serverless 函數

對於需要使用 Serverless 的框架,例如 Next.js (opens in a new tab)Nuxt.js (opens in a new tab) 等等,在 zbpack 構建完的 .zeabur/output 目錄下,會有 staticfunctions 兩個目錄,其中 static 目錄下存放的是靜態資源,而 functions 目錄下存放的是 Serverless 函數。

對於部署在 Zeabur 的服務,可以在服務詳情頁面的右上角看到目前是使用 Serverless 方式還是容器化(Containerized)方式進行部署的:

服務詳情頁面