aws-lambda-3 - AWS 解決方案建構

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

aws-lambda-3

所有類都在積極開發中,並且在任何未來版本中都會受到非向後兼容的更改或刪除。這些不受語義版本控制模型。這意味著,雖然您可以使用它們,但在升級到此軟件包的較新版本時,您可能需要更新源代碼。

請注意: 為了確保功能正確,專案中的 AWS 解決方案建構套件和 AWS CDK 套件必須是相同的版本。

語言 套件
Python
aws_solutions_constructs.aws_lambda_s3
TypeScript
@aws-solutions-constructs/aws-lambda-s3
Java
software.amazon.awsconstructs.services.lambdas3

Overview

此 AWS 解決方案建構實作連接到 Amazon S3 儲存貯體的 AWS Lambda函數。

下面是 TypeScript 中的最小可部署模式定義:

import { LambdaToS3 } from '@aws-solutions-constructs/aws-lambda-s3'; new LambdaToS3(this, 'LambdaToS3Pattern', { lambdaFunctionProps: { runtime: lambda.Runtime.NODEJS_14_X, // This assumes a handler function in lib/lambda/index.js code: lambda.Code.fromAsset(`${__dirname}/lambda`), handler: 'index.handler' } });

Initializer

new LambdaToS3(scope: Construct, id: string, props: LambdaToS3Props);

參數

模式建立道具

名稱 類型 描述
現在還有蘭姆達伯? lambda.Function Lambda 函數對象的現有實例,同時提供這個和lambdaFunctionProps會導致錯誤。
拉姆針灸道具? lambda.FunctionProps 選用的使用者提供的屬性來覆寫 Lambda 函數的預設屬性。忽略existingLambdaObj提供。
現在的巴克托比? s3.IBucket S3 存儲桶對象的現有實例。如果這是提供的,那麼還提供bucketProps是錯誤。
水桶道具? s3.BucketProps 可選的使用者提供的屬性來覆寫儲存貯體的預設屬性。忽略existingBucketObj提供。
儲存區權限? string[] 可選的儲存貯體權限授與 Lambda 函數。可指定下列一或多個:DeletePutReadReadWriteWrite
是否存在 VPC? ec2.IVpc 應該部署此模式的選用現有 VPC。在 VPC 中部署時,Lambda 函數將使用 VPC 中的 ENI 來存取網路資源,並且會在 Amazon SQS 的 VPC 中建立一個介面端點。如果提供了現有的 VPC,deployVpc屬性不能為true。這使用ec2.IVpc,以允許用戶端使用ec2.Vpc.fromLookup()方法。
部署 vPC? boolean 是否建立新的 VPCvpcProps來部署此模式。將此設為true將部署最小的,最私有的 VPC 來運行該模式:
  • CDK 程式使用的每個可用區域內有一個隔離子網路。

  • enableDnsHostnamesenableDnsSupport都將設置為true

如果此屬性為true,然後existingVpc無法指定。預設為 false
VPCProps? ec2.VpcProps 可選的使用者提供的屬性,用於覆寫新 VPC 的預設屬性。enableDnsHostnamesenableDnsSupportnatGatewayssubnetConfiguration是由模式設置的,因此此處提供的屬性的任何值都將被覆蓋。如果deployVpc不是true那麼這個屬性將被忽略。
時段變數名稱? string 為 Lambda 函數設定之 S3 儲存貯體環境變數的選擇性名稱。

模式性質

名稱 類型 描述
LambdaFunction lambda.Function 返回由模式創建的 Lambda 函數的實例。
S3 儲存貯體? s3.Bucket 返回由模式創建的 S3 存儲桶的實例。
S3 記錄桶? s3.Bucket 返回由 S3 存儲桶模式創建的日誌存儲桶的實例。
vpc? ec2.IVpc 返回模式使用的 VPC 的實例(如果有的話)。這可能是由模式或提供給模式構造函數的 VPC 創建的 VPC。

預設定

此模式的開箱即用實現沒有任何覆蓋將設置以下默認值:

AWS Lambda 功能

  • 設定 Lambda 函數的有限權限存取 IAM 角色。

  • 針對 NodeJS Lambda 函數啟用重複使用連線的功能。

  • 啟用 X-Ray 追蹤

  • 設定環境變數:

    • S3_BUCKET_NAME (default)

    • AWS_NODEJS_CONNECTION_REUSE_ENABLED(對於節點 10.x 和更高版本的函數)

Amazon S3 儲存貯體

  • 設定 S3 儲存貯體的存取記錄。

  • 使用 AWS 受管 KMS 金鑰啟用 S3 儲存貯體的伺服器端加密。

  • 打開 S3 存儲桶的版本控制。

  • 不允許公開存取 S3 儲存貯體。

  • 刪除 CloudFormation 堆疊時保留 S3 桶。

  • 強制加密傳輸中的資料。

  • 套用生命週期規則,在 90 天後將非目前物件版本移至 Glacier 儲存區。

Architecture

GitHub

要查看此模式的代碼,創建/查看問題和提取請求,以及更多:
@aws-解決方案-構造/aw-lambda-3