使用 Lambda 內容物件擷取 TypeScript 函數資訊 - AWS Lambda

本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。

使用 Lambda 內容物件擷取 TypeScript 函數資訊

當 Lambda 執行您的函數時,它會將內容物件傳遞至處理常式。此物件提供的方法和各項屬性提供了有關調用、函式以及執行環境的資訊。

內容方法
  • getRemainingTimeInMillis() - 傳回執行逾時前剩餘的毫秒數。

內容屬性
  • functionName – Lambda 函數的名稱。

  • functionVersion – 函數的版本

  • invokedFunctionArn - 用於調用此函數的 Amazon Resource Name (ARN)。指出調用者是否指定版本號或別名。

  • memoryLimitInMB - 分配給函數的記憶體數量。

  • awsRequestId - 調用請求的識別符。

  • logGroupName - 函數的日誌群組。

  • logStreamName - 函數執行個體的記錄串流。

  • identity - (行動應用程式) 已授權請求的 Amazon Cognito 身分的相關資訊。

    • cognitoIdentityId - 已驗證的 Amazon Cognito 身分。

    • cognitoIdentityPoolId - 授權調用的 Amazon Cognito 身分集區。

  • clientContext - (行動應用程式) 用戶端應用程式提供給 Lambda 的用戶端內容。

    • client.installation_id

    • client.app_title

    • client.app_version_name

    • client.app_version_code

    • client.app_package_name

    • env.platform_version

    • env.platform

    • env.make

    • env.model

    • env.locale

    • Custom - 用戶端應用程式所設定的自訂值。

  • callbackWaitsForEmptyEventLoop - 設為 false 將會在回呼執行時立即傳送回應,而不會等待 Node.js 事件迴圈成空白。如果此為 false,任何未完成的事件都會於下次調用時繼續執行。

您可以使用 @types/aws-lambda npm 套件處理內容物件。

範例 index.ts 檔案

以下範例函式紀錄內文資訊和傳回日誌的位置。

注意

在 Lambda 函數中使用這段程式碼之前,您必須先新增 @types/aws-lambda 套件當作開發相依項。此套件包含 Lambda 的類型定義。安裝 @types/aws-lambda 後,import 陳述式 (import ... from 'aws-lambda') 會匯入類型定義。不會匯入 aws-lambda NPM 套件,這是不相關的第三方工具。如需詳細資訊,請參閱 DefinitelyTyped GitHub 儲存庫中的 aws-lambda

import { Context } from 'aws-lambda'; export const lambdaHandler = async (event: string, context: Context): Promise<string> => { console.log('Remaining time: ', context.getRemainingTimeInMillis()); console.log('Function name: ', context.functionName); return context.logStreamName; };