レイヤード・ランダムズ: AWS SAM と Python

コードの再利用性を少しでも高めることは決して悪くない。

目次

AWS Lambda にレイヤーを追加する方法についてのステップバイステップの手順です - Python で実施します。 標準の HelloWorld テンプレート例によって生成されたベースコードを使用します。

letters-layers

もちろん、Python と AWS SAM の関連するものを事前にインストールし、設定しておく必要があります。

サンプルプロジェクトの生成と実行

今度は sam init を実行し、標準的な方法で質問に答えてください。以下のようにしてください:

sam-init-answers

要約が表示されます:

sam-init-summary

そして、プロジェクトフォルダが作成され、構造といくつかのファイルが生成されます。template.yaml は標準的な形式です。

vs-code-template-yaml

関数コードも同様です(余分な生成されたコメントは削除します)。

import json

def lambda_handler(event, context):

    return {
        "statusCode": 200,
        "body": json.dumps({
            "message": "hello world",
            # "location": ip.text.replace("\n", "")
        }),
    }

今度はこの関数をローカルでビルドして呼び出しましょう

sam validate && sam build --use-container && sam local invoke HelloWorldFunction --event events/event.json

応答の最後は以下のものに近いはずです:

.....
START RequestId: 6da35464-7c6a-40b2-bcc0-60796994317a Version: $LATEST
END RequestId: 737ae28d-2b99-49e6-baae-40ab9bb99599
REPORT RequestId: 737ae28d-2b99-49e6-baae-40ab9bb99599  Init Duration: 0.04 ms  Duration: 28.40 ms      Billed Duration: 29 ms  Memory Size: 128 MB     Max Memory Used: 128 MB
{"statusCode": 200, "body": "{\"message\": \"hello world\"}"}

レイヤーの追加

template.yaml にレイヤーの説明を追加

2つの部分があります:

  • ApiSharedLayer - その説明を記述するブロック
  • Layers: … - !Ref ApiSharedLayer - それを使用する関数内に
.....
Resources:
# added code start
    ApiSharedLayer:
        Type: AWS::Serverless::LayerVersion
        Properties:
            ContentUri: api_shared_layer/
            LayerName: api-shared-layer
            Description: My api-shared-layer
            CompatibleRuntimes:
                - python3.9
            RetentionPolicy: Delete                
        Metadata:
            BuildMethod: python3.9   # AWS SAM がこのレイヤーをビルドするために必要
# added code end

  HelloWorldFunction:
    Type: AWS::Serverless::Function # Function Resource に関する詳細情報: https://github.com/awslabs/serverless-application-model/blob/master/versions/2016-10-31.md#awsserverlessfunction
    Properties:
      CodeUri: hello_world/
      Handler: app.lambda_handler
      Runtime: python3.9
      Architectures:
        - x86_64
# added code start
      Layers:
        - !Ref ApiSharedLayer
# added code end
      Events:
.....

レイヤーのコードを追加

api_shared_layer フォルダにいくつかのコードを追加してください

layer code

関数をこのコードを使用するように更新

import json
from api_version import API_VERSION

def lambda_handler(event, context):

    return {
        "statusCode": 200,
        "body": json.dumps({
            "message": "hello world",
            "version": API_VERSION
        }),
    }

テスト実行

再度実行してください:

sam validate && sam build --use-container && sam local invoke HelloWorldFunction --event events/event.json

応答の最後は以下のものに近いはずです:

.....
START RequestId: 88eb1887-ae94-479d-a059-f87c4b71a282 Version: $LATEST
END RequestId: 927f7d05-4d13-44ba-9377-03e6d3e8bacf
REPORT RequestId: 927f7d05-4d13-44ba-9377-03e6d3e8bacf  Init Duration: 0.72 ms  Duration: 34.80 ms      Billed Duration: 35 ms  Memory Size: 128 MB     Max Memory Used: 128 MB
{"statusCode": 200, "body": "{\"message\": \"hello world\", \"version\": \"1.1.1\"}"}

素晴らしいです。

有用なリンク