搜尋
首頁後端開發Python教學Azure Functions 與 Python:觸發器

Azure Functions with Python: Triggers

Python 開發人員可以使用 Azure Functions 建立輕量級、可擴充且高效的無伺服器應用程式。在這篇文章中,我們將重點放在觸發器上。

Azure Functions 中的觸發器是什麼?

觸發器是 Azure Functions 的基礎。它們決定如何呼叫函數。每個函數必須有一個觸發器,而觸發器類型決定了該函數可用的資料負載。 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 儲存體中的變更(例如檔案上傳)。
  • 範例:
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 資料的參數名稱。這是我的blob。
  • path: 函數偵聽的 Blob 儲存容器中的路徑。在此範例中,它是 blobname。
  • connection: 指包含 Blob 儲存帳戶的連接字串的應用程式設定的名稱。這是 BlobStorageConnectionString。

4.隊列觸發

  • 由新增至 Azure 儲存體佇列的訊息觸發。
  • 範例:
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:指定函數中代表佇列訊息的參數名稱。在這裡,是 azqueue。
  • queue_name:函數偵聽的 Azure 儲存佇列的名稱。在本例中,它是佇列名稱。
  • 連線:指包含 Azure 儲存佇列連接字串的應用程式設定。在這裡,它是 QueueConnectionString。

5.事件中心觸發器

  • 由傳送到 Azure 事件中心的事件觸發。
  • 範例:
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 替換為事件中心的實際名稱。
  • 連線: 這是指包含事件中心連接字串的應用程式設定的名稱。確保 Azure Function App 的設定包含名為 EventHubConnectionString 的項目以及對應的連線字串值。

6.服務總線隊列觸發器

  • 由新增至 Azure 服務總線佇列的訊息觸發。
  • 範例:
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: 這表示函數正在偵聽的服務總線佇列的名稱。將 servicebusqueuename 替換為您的服務總線佇列的實際名稱。
  • connection: 這是指包含服務匯流排連接字串的應用程式設定的名稱。確保 Azure Function App 的設定包含名為 ServiceBusConnectionString 的條目以及對應的連接字串值。

7. ServiceBus 主題觸發器

  • 由發佈到 Azure 服務總線主題的訊息觸發。
  • 範例:
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:指定函數中代表服務總線訊息的參數名稱。在這裡,它是 azservicebus。
  • subscription_name:觸發器偵聽的服務總線訂閱的名稱。
  • topic_name:觸發器偵聽的服務總線主題的名稱。在此範例中,它是 servicebustopicname。
  • 連線:指包含 Azure 服務匯流排命名空間的連線字串的應用程式設定。這裡是ServiceBusConnectionString。

其他觸發因素

  • Cosmos DB 觸發器: 利用變更來源機制來回應 Azure Cosmos DB 資料庫中的變更(插入和更新)。
  • Dapr 發布輸出綁定: 允許函數在執行期間將訊息發佈到 Dapr 主題,從而促進微服務之間的通訊。
  • Dapr 服務呼叫觸發器: 允許其他支援 Dapr 的服務直接呼叫函數,支援服務到服務通訊。
  • Dapr 主題觸發器: 執行函數以回應透過 Dapr 的發布-訂閱訊息傳遞模式發佈到特定主題的訊息。
  • 事件網格觸發器:當事件傳送到 Azure 事件網格主題時啟動函數,從而實現反應式事件驅動架構。

以上是Azure Functions 與 Python:觸發器的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
Python中的合併列表:選擇正確的方法Python中的合併列表:選擇正確的方法May 14, 2025 am 12:11 AM

Tomergelistsinpython,YouCanusethe操作員,estextMethod,ListComprehension,Oritertools

如何在Python 3中加入兩個列表?如何在Python 3中加入兩個列表?May 14, 2025 am 12:09 AM

在Python3中,可以通過多種方法連接兩個列表:1)使用 運算符,適用於小列表,但對大列表效率低;2)使用extend方法,適用於大列表,內存效率高,但會修改原列表;3)使用*運算符,適用於合併多個列表,不修改原列表;4)使用itertools.chain,適用於大數據集,內存效率高。

Python串聯列表字符串Python串聯列表字符串May 14, 2025 am 12:08 AM

使用join()方法是Python中從列表連接字符串最有效的方法。 1)使用join()方法高效且易讀。 2)循環使用 運算符對大列表效率低。 3)列表推導式與join()結合適用於需要轉換的場景。 4)reduce()方法適用於其他類型歸約,但對字符串連接效率低。完整句子結束。

Python執行,那是什麼?Python執行,那是什麼?May 14, 2025 am 12:06 AM

pythonexecutionistheprocessoftransformingpypythoncodeintoExecutablestructions.1)InternterPreterReadSthecode,ConvertingTingitIntObyTecode,whepythonvirtualmachine(pvm)theglobalinterpreterpreterpreterpreterlock(gil)the thepythonvirtualmachine(pvm)

Python:關鍵功能是什麼Python:關鍵功能是什麼May 14, 2025 am 12:02 AM

Python的關鍵特性包括:1.語法簡潔易懂,適合初學者;2.動態類型系統,提高開發速度;3.豐富的標準庫,支持多種任務;4.強大的社區和生態系統,提供廣泛支持;5.解釋性,適合腳本和快速原型開發;6.多範式支持,適用於各種編程風格。

Python:編譯器還是解釋器?Python:編譯器還是解釋器?May 13, 2025 am 12:10 AM

Python是解釋型語言,但也包含編譯過程。 1)Python代碼先編譯成字節碼。 2)字節碼由Python虛擬機解釋執行。 3)這種混合機制使Python既靈活又高效,但執行速度不如完全編譯型語言。

python用於循環與循環時:何時使用哪個?python用於循環與循環時:何時使用哪個?May 13, 2025 am 12:07 AM

UseeAforloopWheniteratingOveraseQuenceOrforAspecificnumberoftimes; useAwhiLeLoopWhenconTinuingUntilAcIntiment.forloopsareIdealForkNownsences,而WhileLeleLeleLeleLeleLoopSituationSituationsItuationsItuationSuationSituationswithUndEtermentersitations。

Python循環:最常見的錯誤Python循環:最常見的錯誤May 13, 2025 am 12:07 AM

pythonloopscanleadtoerrorslikeinfiniteloops,modifyingListsDuringteritation,逐個偏置,零indexingissues,andnestedloopineflinefficiencies

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。