本文以安裝第三方依賴emoji為例,介紹如何為您的Node.js代碼安裝依賴,打包並部署代碼至Function Compute。
準備工作
建立一個用於測試的代碼目錄,如
mycode。Linux或macOS系統
您可以執行
mkdir -p /tmp/mycode建立。Windows系統
在任意位置建立檔案夾,並將其命名為
mycode即可。
在
mycode目錄下,建立index.js或index.mjs檔案。程式碼範例如下。
ES模組
說明此樣本僅支援運行在Node.js 18及以上版本的運行時環境。
// index.mjs 'use strict'; import * as emoji from 'node-emoji' export const handler = async (event, context) => { console.log('hello world'); return emoji.get(':unicorn:'); }CommonJS模組
// index.js 'use strict'; var emoji = require('node-emoji') exports.handler = (event, context, callback) => { console.log('hello world'); callback(null, emoji.get(':unicorn:');); }
使用npm安裝依賴並部署代碼
前提條件
您的本機已安裝npm,且具有執行npm命令的許可權。
您已在Function Compute控制台建立Node.js函數。具體操作,請參見建立函數。
操作步驟
在
mycode目錄下執行npm install node-emoji安裝emoji依賴庫到目前的目錄。打包
mycode目錄下的所有檔案。Linux或macOS系統
進入
mycode目錄,執行zip code.zip -r ./*。說明請確保您具有該目錄的讀寫權限。
Windows系統
進入
mycode目錄,選中所有檔案,單擊滑鼠右鍵,選擇打包為ZIP包。
說明請確保您建立的
index.js檔案位於包的根目錄。在Function Compute控制台找到目標函數,然後在函數詳情頁面的右上方,單擊上傳代碼上傳您上一步打包的ZIP包。
由於Function Compute的運行環境是Linux系統,您在Windows系統或macOS系統安裝emoji依賴庫時如果帶有二進位檔案,會導致您的程式碼封裝上傳到Function Compute後運行失敗。因此,建議您使用WebIDE打包函數第三方依賴或者使用Serverless devs工具安裝依賴並部署專案。
使用Serverless devs工具安裝依賴並部署專案
前提條件
操作步驟
執行
cd /tmp/mycode進入mycode目錄。新增
s.yaml檔案。編寫檔案內容樣本如下。
edition: 1.0.0 # 命令列YAML規範版本,遵循語義化版本(Semantic Versioning)規範 name: fcDeployApp # 專案名稱 access: "default" # 密鑰別名 services: fc-deploy-test: # 服務名稱 component: fc # 組件名稱 props: # 組件的屬性值 region: cn-shanghai service: name: fctest description: 'test' internetAccess: true function: name: emoji description: this is a emoji runtime: nodejs14 codeUri: ./ handler: index.handler memorySize: 128 timeout: 6新增
package.json檔案。編寫檔案內容如下。
{ "dependencies": { "node-emoji": "^1.11.0" } }執行
sudo s build --use-docker安裝依賴。執行完成後,會在
mycode目錄下產生一個.s目錄,依賴被安裝到.s/build/artifacts/{serviceName}/{functionName}目錄下。執行
sudo s deploy部署專案。執行完成後,即可部署函數到Function Compute。
更多資訊
您也可以使用Function Compute的層功能安裝依賴,推薦您使用官方公用層或線上構建依賴層。具體操作,請參見以下文檔。