快速遷移 Next.js 應用到函數計算

首先介紹下在本文出現的幾個比較重要的概念:html

函數計算(Function Compute): 函數計算是一個事件驅動的服務,經過函數計算,用戶無需管理服務器等運行狀況,只需編寫代碼並上傳。函數計算準備計算資源,並以彈性伸縮的方式運行用戶代碼,而用戶只需根據實際代碼運行所消耗的資源進行付費。函數計算更多信息 參考。 Fun: Fun 是一個用於支持 Serverless 應用部署的工具,能幫助您便捷地管理函數計算、API 網關、日誌服務等資源。它經過一個資源配置文件(template.yml),協助您進行開發、構建、部署操做。Fun 的更多文檔 參考前端

備註: 本文介紹的技巧須要 Fun 版本大於等於 3.7.0。react

背景

Next.js 是一種 React 的服務端渲染框架,且 Next.js 集成度極高,框架自身集成了 webpack、babel、express 等,使得開發者能夠僅依賴 Next、react、react-dom 就能夠很是方便的構建本身的 SSR React 應用,開發者甚至都不用像之前那樣關心路由。 Next.js 的高度集成性,使得咱們很容易就能實現代碼分割、路由跳轉、熱更新以及服務端渲染和前端渲染。webpack

環境準備

首先按照 Fun 的 安裝文檔 裏介紹的方法將 Fun 安裝到本機。 PS: 本文介紹的方法,不須要安裝 Docker,僅僅安裝 Fun 便可,最簡單的方式就是直接下載可執行的二進制文件。 安裝完成後,能夠執行 fun --version 檢查 Fun 是否安裝成功。git

快速開始

  1. 建立一個 Next 項目,這裏以 nextjs 爲例:
npm init next-app
  1. 進入到剛剛建立的示例項目中:
cd nextjs
  1. 本地運行測試該示例:
npm run dev 或者 yarn dev

效果以下: 20200313103411.jpggithub

  1. 編譯 nextjs 項目:
npm run build
  1. 部署項目到函數計算: 僅須要一個命令fun deploy,Fun 會自動進入部署流程,在該流程中,用戶僅僅須要按下一系列的回車便可。流程細節以下:web

    1. Fun 檢測到這不是一個 Fun 項目,會提示協助建立(直接回車或者輸入 y 便可): 20200313105720.jpg
    2. Fun 項目自動建立成功,提示是否進行部署?能夠直接回車,或者輸入 y 進行確認: 20200313111040.jpg
    3. 而後 Fun 會直接將應用部署到線上了。 20200313111259.jpg 部署完成後,咱們能夠根據部署成功的日誌看到,函數計算爲咱們生成了臨時域名 14069166-1986114430573743.test.functioncompute.com,咱們能夠經過這個臨時域名直接訪問咱們剛剛部署的應用。 注意:臨時域名僅僅用做演示以及開發,是有時效的,若是用做生產,請綁定已經備案的域名,綁定自定義域名能夠參考 詳情

總結

本文主要介紹瞭如何將 Next.js 應用部署到函數計算。相比較與傳統的部署方法,不只沒有更復雜,還省略了購買機器等步驟。實現,將傳統的 Next.js 應用在本地開發完成後,一鍵部署到遠端直接用於生產,並擁有了彈性伸縮、按量付費、免運維等特性。express

阿里巴巴雲原生關注微服務、Serverless、容器、Service Mesh 等技術領域、聚焦雲原生流行技術趨勢、雲原生大規模的落地實踐,作最懂雲原生開發者的技術圈。」npm

相關文章
相關標籤/搜索