検索
ホームページバックエンド開発Python チュートリアルPython を使用した Azure Functions: トリガー

Azure Functions with Python: Triggers

Python 開発者は、Azure Functions を使用して、軽量でスケーラブルで効率的なサーバーレス アプリケーションを作成できます。この投稿では、トリガーに焦点を当てます。

Azure Functions のトリガーとは何ですか?

トリガーは Azure Functions の基礎です。これらは、関数の呼び出し方法を決定します。各関数にはトリガーが 1 つだけ必要であり、トリガーのタイプによって関数で使用できるデータ ペイロードが決まります。 Azure は、次のようなさまざまなトリガーをサポートしています。

1. HTTPトリガー

  • HTTP リクエスト経由で関数を呼び出すことができます。
  • API の構築や Webhook への応答に役立ちます。
  • 例:
import azure.functions as func
import datetime
import json
import logging

app = func.FunctionApp()

@app.route(route="http_trigger", auth_level=func.AuthLevel.ANONYMOUS)
def http_trigger(req: func.HttpRequest) -> func.HttpResponse:
    logging.info('Python HTTP trigger function processed a request.')

    return func.HttpResponse("Hello world from HTTP trigger")

パラメータ:

  • route: HTTP トリガーが応答する URL パスを指定します。この場合、関数は /api/http_trigger.
  • でアクセスできます。
  • auth_level: 関数の認証レベルを決定します。オプションには次のものが含まれます。
    • 匿名: 認証は必要ありません。
    • 機能: 機能固有のキーが必要です。
    • ADMIN: 管理者レベルのキーが必要です。

2.タイマートリガー

  • スケジュールに基づいて機能を実行します。
  • Cron 式はスケジュールに使用されます。
  • 例:
import azure.functions as func
import datetime
import json
import logging

app = func.FunctionApp()

@app.timer_trigger(schedule="0 */5 * * * *", arg_name="myTimer", run_on_startup=False, use_monitor=False)
def timer_trigger(myTimer: func.TimerRequest) -> None:

    if myTimer.past_due:
        logging.info('The timer is past due!')

    logging.info('Python timer trigger function executed.')

パラメータ:

  • schedule: CRON 式を使用してスケジュールを定義します。ここで、 0 */5 * * * * は、関数が 0 秒目から開始して 5 分ごとに実行されることを指定します。
  • arg_name: TimerRequest オブジェクトを表す、関数に渡される引数の名前。
  • run_on_startup: True に設定すると、アプリの起動時に関数がすぐに実行されます。デフォルトは False です。
  • use_monitor: Azure がスケジュールの実行漏れを監視するかどうかを決定します。 True の場合、Azure は失敗した実行を確実に再試行します。デフォルトは True です。この例では、False に設定されています。

3.ブロブトリガー

  • Azure Blob Storage の変更 (ファイルのアップロードなど) に応答します。
  • 例:
import azure.functions as func
import datetime
import json
import logging

app = func.FunctionApp()

@app.blob_trigger(arg_name="myblob", path="blobname", connection="BlobStorageConnectionString")
def BlobTrigger(myblob: func.InputStream):
    logging.info(f"Python blob trigger function processed blob"
                f"Name: {myblob.name}"
                f"Blob Size: {myblob.length} bytes")

パラメータ:

  • arg_name: BLOB データを表す関数の引数の名前を指定します。これが myblob です。
  • path: 関数がリッスンする Blob Storage コンテナー内のパス。この例では、blobname です。
  • connection: Blob Storage アカウントの接続文字列を含むアプリケーション設定の名前を参照します。ここでは BlobStorageConnectionString です。

4.キュートリガー

  • Azure Storage Queue に追加されたメッセージによってトリガーされます。
  • 例:
import azure.functions as func
import datetime
import json
import logging

app = func.FunctionApp()

@app.route(route="http_trigger", auth_level=func.AuthLevel.ANONYMOUS)
def http_trigger(req: func.HttpRequest) -> func.HttpResponse:
    logging.info('Python HTTP trigger function processed a request.')

    return func.HttpResponse("Hello world from HTTP trigger")

パラメータ:

  • arg_name: 関数内のキュー メッセージを表す引数の名前を指定します。こちら、アズキューです
  • queue_name: 関数がリッスンする Azure ストレージ キューの名前。この場合、それはキュー名です。
  • connection: Azure Storage Queue の接続文字列を含むアプリケーション設定を指します。ここでは、QueueConnectionString です。

5.イベントハブトリガー

  • Azure Event Hub に送信されたイベントによってトリガーされます。
  • 例:
import azure.functions as func
import datetime
import json
import logging

app = func.FunctionApp()

@app.timer_trigger(schedule="0 */5 * * * *", arg_name="myTimer", run_on_startup=False, use_monitor=False)
def timer_trigger(myTimer: func.TimerRequest) -> None:

    if myTimer.past_due:
        logging.info('The timer is past due!')

    logging.info('Python timer trigger function executed.')

パラメータ:

  • arg_name: これは、関数内でイベント データを受け取るパラメーターの名前を指定します。この場合、azeventhub は受信 EventHubEvent を表す変数になります。
  • event_hub_name: これは、関数がリッスンしているイベント ハブの名前を示します。 eventhubname をイベント ハブの実際の名前に置き換えます。
  • connection: これは、イベント ハブの接続文字列を含むアプリケーション設定の名前を指します。 Azure Function App の設定に、適切な接続文字列値を含む EventHubConnectionString という名前のエントリが含まれていることを確認してください。

6. ServiceBus キュー トリガー

  • Azure Service Bus キューに追加されたメッセージによってトリガーされます。
  • 例:
import azure.functions as func
import datetime
import json
import logging

app = func.FunctionApp()

@app.blob_trigger(arg_name="myblob", path="blobname", connection="BlobStorageConnectionString")
def BlobTrigger(myblob: func.InputStream):
    logging.info(f"Python blob trigger function processed blob"
                f"Name: {myblob.name}"
                f"Blob Size: {myblob.length} bytes")

パラメータ:

  • arg_name: これは、関数内でメッセージ データを受け取るパラメーターの名前を指定します。この場合、azservicebus は受信 ServiceBusMessage を表す変数になります。
  • queue_name: これは、関数がリッスンしている Service Bus キューの名前を示します。 servicebusqueuename を Service Bus キューの実際の名前に置き換えます。
  • connection: これは、Service Bus の接続文字列を含むアプリケーション設定の名前を指します。 Azure Function App の設定に、適切な接続文字列値を含む ServiceBusConnectionString という名前のエントリが含まれていることを確認してください。

7. ServiceBus トピックのトリガー

  • Azure Service Bus トピックにパブリッシュされたメッセージによってトリガーされます。
  • 例:
import azure.functions as func
import datetime
import json
import logging

app = func.FunctionApp()

@app.route(route="http_trigger", auth_level=func.AuthLevel.ANONYMOUS)
def http_trigger(req: func.HttpRequest) -> func.HttpResponse:
    logging.info('Python HTTP trigger function processed a request.')

    return func.HttpResponse("Hello world from HTTP trigger")

パラメータ:

  • arg_name: 関数内の Service Bus メッセージを表す引数の名前を指定します。ここでは、azservicebus です。
  • subscription_name: トリガーがリッスンする Service Bus サブスクリプションの名前。
  • topic_name: トリガーがリッスンする Service Bus トピックの名前。この例では、servicebustopicname.
  • です。
  • connection: Azure Service Bus 名前空間の接続文字列を含むアプリケーション設定を指します。ここでは、ServiceBusConnectionString です。

その他のトリガー

  • Cosmos DB トリガー: 変更フィード メカニズムを利用して、Azure Cosmos DB データベースの変更 (挿入と更新) に応答します。
  • Dapr Publish Output Binding: 関数が実行中にメッセージを Dapr トピックに発行できるようにし、マイクロサービス間の通信を容易にします。
  • Dapr サービス呼び出しトリガー: 他の Dapr 対応サービスによって関数を直接呼び出せるようにし、サービス間通信をサポートします。
  • Dapr トピック トリガー: Dapr のパブリッシュ/サブスクライブ メッセージング パターンを介して特定のトピックにパブリッシュされたメッセージに応答して関数を実行します。
  • Event Grid トリガー: イベントが Azure Event Grid トピックに送信されるときに関数をアクティブ化し、リアクティブなイベント駆動型アーキテクチャを可能にします。

以上がPython を使用した Azure Functions: トリガーの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Pythonアレイをどのようにスライスしますか?Pythonアレイをどのようにスライスしますか?May 01, 2025 am 12:18 AM

Pythonリストスライスの基本的な構文はリストです[start:stop:step]。 1.STARTは最初の要素インデックス、2。ストップは除外された最初の要素インデックスであり、3.ステップは要素間のステップサイズを決定します。スライスは、データを抽出するためだけでなく、リストを変更および反転させるためにも使用されます。

どのような状況で、リストは配列よりもパフォーマンスが向上しますか?どのような状況で、リストは配列よりもパフォーマンスが向上しますか?May 01, 2025 am 12:06 AM

ListSoutPerformArraysIn:1)ダイナミシジョンアンドフレーケンティオン/削除、2)ストーリングヘテロゼンダタ、および3)メモリ効率の装飾、ButmayhaveslightPerformancostsinceNASOPERATIONS。

PythonアレイをPythonリストに変換するにはどうすればよいですか?PythonアレイをPythonリストに変換するにはどうすればよいですか?May 01, 2025 am 12:05 AM

toconvertapythonarraytoalist、usetheList()constructororageneratorexpression.1)importhearraymoduleandcreateanarray.2)useList(arr)または[xforxinarr] toconvertoalistは、largedatatessを変えることを伴うものです。

Pythonにリストが存在する場合、配列を使用する目的は何ですか?Pythonにリストが存在する場合、配列を使用する目的は何ですか?May 01, 2025 am 12:04 AM

choosearraysoverlistsinperbetterperformance andmemoryeficiencyspecificscenarios.1)largeNumericaldatasets:Araysreducememoryusage.2)パフォーマンス - クリティカル操作:ArraysOfferSpeedBoostsfortsfortsclikeappendedoring.3)タイプリー:Arrayesenforc

リストの要素と配列を繰り返す方法を説明します。リストの要素と配列を繰り返す方法を説明します。May 01, 2025 am 12:01 AM

Pythonでは、ループに使用し、列挙し、包括的なリストを通過することができます。 Javaでは、従来のループを使用し、ループを強化してアレイを通過することができます。 1。Pythonリストトラバーサル方法は、ループ、列挙、およびリスト理解のためのものです。 2。Javaアレイトラバーサル法には、従来のループとループ用の強化が含まれます。

Python Switchステートメントとは何ですか?Python Switchステートメントとは何ですか?Apr 30, 2025 pm 02:08 PM

この記事では、バージョン3.10で導入されたPythonの新しい「マッチ」ステートメントについて説明します。これは、他の言語のスイッチステートメントに相当するものです。コードの読みやすさを向上させ、従来のif-elif-elよりもパフォーマンスの利点を提供します

Pythonの例外グループとは何ですか?Pythonの例外グループとは何ですか?Apr 30, 2025 pm 02:07 PM

Python 3.11の例外グループは、複数の例外を同時に処理することで、同時シナリオと複雑な操作でエラー管理を改善します。

Pythonの関数注釈とは何ですか?Pythonの関数注釈とは何ですか?Apr 30, 2025 pm 02:06 PM

Pythonの関数注釈は、タイプチェック、ドキュメント、およびIDEサポートの関数にメタデータを追加します。それらはコードの読みやすさ、メンテナンスを強化し、API開発、データサイエンス、ライブラリの作成において重要です。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境