

サポート終了通知: 2026 年 10 月 7 日、 AWS はサポートを終了します AWS IoT Greengrass Version 1。2026 年 10 月 7 日以降、 AWS IoT Greengrass V1 リソースにアクセスできなくなります。詳細については、[「 からの移行 AWS IoT Greengrass Version 1](https://docs.aws.amazon.com/greengrass/v2/developerguide/migrate-from-v1.html)」を参照してください。

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

# オンデマンド Lambda 関数のテスト
<a name="on-demand"></a>

*[オンデマンド](lambda-functions.md#lambda-lifecycle)* Lambda 関数は、クラウドベースの AWS Lambda 関数と似ています。オンデマンド Lambda 関数の複数の呼び出しは、同時に実行できます。Lambda 関数の呼び出しは、呼び出し処理に別のコンテナを作成するか、あるいは、リソースで許可される場合には、既存のコンテナを再使用します。関数ハンドラの外部で定義される変数や前処理は、作成したコンテナには保持されません。

1. グループ設定ページで、**[Lambda functions]** (Lambda 関数) タブを選択します。

1. **[My Lambda functions]** (自分の Lambda 関数)で、**Greengrass\$1HelloWorld\$1Counter**[Lambda function](Lambda 関数) を選択します。

1. **Greengrass\$1HelloWorld\$1Counter** [details](詳細) ページで、**[Edit]** (編集) を選択します。

1. **[Pinned]** (固定) で、**[False]**、**[Save]** (保存) の順に選択します。

1. <a name="console-actions-deploy"></a>グループ設定ページで、**[Deploy]** (デプロイ) を選択します。

1. <a name="console-test-after-deploy"></a>デプロイが完了したら、 AWS IoT コンソールのホームページに戻り、**テスト**を選択します。

1. 以下のフィールドを設定します。
   + [**Subscription topic (サブスクリプショントピック)**] で、**hello/world/counter** と入力します。
   + [**サービスの品質**] で [**0**] を選択します。
   + [**MQTT ペイロード表示**] で、[**ペイロードを文字列として表示 (より正確)**] を選択します。  
![\[[サブスクリプションテスト] ページのスクリーンショット。\]](http://docs.aws.amazon.com/ja_jp/greengrass/v1/developerguide/images/gg-get-started-056.png)

1. **[サブスクライブ]** を選択します。
**注記**  
サブスクリプション後にメッセージは表示されません。

1. オンデマンドのライフサイクルをテストするには、`hello/world/counter/trigger` トピックにメッセージを発行することで、関数を呼び出します。デフォルトのメッセージを使用できます。

   1. ボタンを押すたびに 5 秒以内に、**[Publish]** (発行) を 3 回すばやく選択します。  
![\[すばやく 3 回クリックする必要がある [トピックに発行] ボタンを示すスクリーンショット。\]](http://docs.aws.amazon.com/ja_jp/greengrass/v1/developerguide/images/gg-get-started-063.png)

      発行ごとに、関数ハンドラが呼び出され、各呼び出しのコンテナが作成されます。各オンデマンド Lambda 関数に独自のコンテナ/サンドボックスがあるため、3 回関数をトリガーしても呼び出しカウントが増分されることはありません。  
![\[[呼び出しカウント] が 1 で固定されていることを示すスクリーンショット。\]](http://docs.aws.amazon.com/ja_jp/greengrass/v1/developerguide/images/gg-get-started-064.png)

   1. 約 30 秒待機してから [**トピックに発行**] を選択します。呼び出しカウントを 2 に増分する必要があります。これは、前の呼び出しで以前に作成されたコンテナが再利用されており、関数ハンドラの外部の前処理変数が保存されていることを示しています。  
![\[[呼び出しカウント] が現在 2 であることを示すスクリーンショット。\]](http://docs.aws.amazon.com/ja_jp/greengrass/v1/developerguide/images/gg-get-started-065.png)

これで、 AWS IoT Greengrass コア上で実行できる 2 つのタイプの Lambda 関数を理解しました。次のモジュールである[モジュール 4](module4.md) では、ローカル IoT デバイスが AWS IoT Greengrass グループ内でどのようにやり取りできるかを示します。