在 Azure 中建立由 Blob 儲存體所觸發的函式
了解如何建立函式,並讓此函式在檔案上傳至 Blob 儲存體容器時或 Blob 儲存體容器中的檔案更新時觸發。
注意
入口網站內編輯僅支援 JavaScript、PowerShell 和 C# 指令碼函式。 只有在「使用量」方案中執行時,才支援 Python 入口網站內編輯。 若要建立支援入口網站內編輯的 C# 指令碼應用程式,您必須選擇支援內含式模型的執行階段版本。
可能的話,您應該在本機開發函式。
若要深入了解在 Azure 入口網站中編輯函式程式碼的限制,請參閱 Azure 入口網站中的開發限制。
必要條件
- Azure 訂用帳戶。 如果您沒有 Azure 訂用帳戶,請在開始前建立免費帳戶。
建立 Azure 函數應用程式
從 Azure 入口網站功能表或 [首頁] 頁面,選取 [建立資源]。
在 [新增] 頁面中,選取 [計算]>[函數應用程式]。
在 [選取主機選項] 下,選取 [使用量]>[選取],在預設的 [使用量] 方案中建立您的應用程式。 在此無伺服器裝載選項中,您只需支付函數執行的時間。 進階方案也提供動態調整。 在 App Service 方案中執行時,您必須管理函式應用程式的調整。
在 [基本] 頁面中,使用下表中指定的函式應用程式設定。
設定 建議的值 描述 訂用帳戶 您的訂用帳戶 用於建立新函數應用程式的訂用帳戶。 資源群組 myResourceGroup 要在其中建立函數應用程式的新資源群組名稱。 您應該建立新的資源群組,因為在現有的資源群組中建立新的函數應用程式時,存在已知的限制。 函數應用程式名稱 全域唯一的名稱 用以識別新函式應用程式的名稱。 有效的字元是 a-z
(不區分大小寫)、0-9
和-
。執行階段堆疊 慣用語言 選擇支援您慣用函式程式設計語言的執行階段。 入口網站內編輯僅適用於 JavaScript、PowerShell、Python、TypeScript 和 C# 指令碼。
若要建立支援入口網站內編輯的 C# 指令碼應用程式,您必須選擇支援內含式模型的執行階段版本。
C# 類別庫和 Java 函式必須在本機開發。版本 版本號碼 選擇已安裝的執行階段版本。 區域 慣用區域 選取的區域應靠近您或靠近函式能夠存取的其他服務。 作業系統 Windows 系統會根據執行階段堆疊選項預先選取作業系統,但您可以視需要變更設定。 入口網站內編輯僅在 Windows 上提供支援。 接受其餘索引標籤中的預設選項,包括在 [儲存體] 索引標籤上建立新儲存體帳戶的默認行為,以及在 [監視] 索引標籤上建立新的 Application Insights 執行個體。您也可以選擇使用現有的儲存體帳戶或 Application Insights 執行個體。
選取 [檢閱 + 建立] 以檢閱所選的應用程式設定,然後選取 [建立] 來佈建和部署函數應用程式。
選取入口網站右上角的 [通知] 圖示,查看是否有 [部署成功] 訊息。
選取 [前往資源],以檢視您新的函式應用程式。 您也可以選取 [釘選到儀表板]。 釘選可讓您更輕鬆地從儀表板返回此函式應用程式資源。
您已成功建立新的函數應用程式。 接下來,您要在新的函式應用程式中建立函式。
建立由 Azure Blob 儲存體所觸發的函式
在函數應用程式中的 [函式] 下,依序選取 [概觀]、[+ 建立]。
在 [選取範本] 下,選擇 [Blob 觸發程序] 範本,然後選取 [下一步]。
在 [範本詳細資料] 中,使用此資料表中指定的設定來設定新觸發程序,然後選取 [建立]:
設定 建議的值 描述 工作類型 附加至應用程式 您只會看到這個 Python v2 應用程式的設定。 新增函式 函式應用程式中的唯一名稱 這個由 blob 所觸發之函式的名稱。 路徑 samples-workitems/{name} 受監視 Blob 儲存體中的位置。 在繫結中,Blob 的檔案名稱會以「名稱」參數的形式來傳遞。 儲存體帳戶連線 AzureWebJobsStorage 您可以使用應用程式函式已在使用的儲存體帳戶連線,或建立新的連線。 Azure 會根據提供的值建立 Blob 儲存體觸發的函式。 接下來,建立 samples-workitems 容器。
建立容器
返回函數應用程式的 [概觀] 頁面、選取您的資源群組,然後尋找並選取資源群組中的儲存體帳戶。
在儲存體帳戶頁面中,選取 [資料儲存體]>[容器]>[+ 容器]。
在 [名稱] 欄位中,輸入
samples-workitems
,然後選取 [建立] 以建立容器。選取您用來測試函式的新
samples-workitems
容器,方法是將檔案上傳至容器。
測試函式
在新瀏覽器視窗中,返回函數應用程式頁面,然後選取 [記錄資料流],以顯示應用程式的即時記錄。
從
samples-workitems
容器頁面中,選取 [上傳]>[瀏覽檔案],瀏覽至本機電腦上的檔案 (例如影像檔),然後選擇檔案。選取 [開啟],然後選取 [上傳]。
返回您的函數應用程式記錄,並確認系統已讀取 Blob。
注意
當函式應用程式以預設的取用方案執行時,從有 Blob 新增或更新到系統觸發函式,中間可能會延遲好幾分鐘。 如果您需要 Blob 所觸發函式中的低延遲,請考慮下列其中一個其他 Blob 觸發程序選項。
清除資源
此集合中的其他快速入門會以本快速入門為基礎。 如果您打算繼續進行後續的快速入門、教學課程或者您在本快速入門中建立的任何服務,請勿清除資源。
在 Azure 中「資源」是指函式應用程式、函式、儲存體帳戶等等。 其會分組為「資源群組」,您可以藉由刪除群組來刪除群組中的所有項目。
您已建立完成這些快速入門所需的資源。 您可能必須支付這些資源,取決於您的帳戶狀態和服務定價。 如果您不再需要資源,刪除方式如下:
在 Azure 入口網站中,移至 [資源群組] 分頁。
若要從函數應用程式頁面移至該頁面,選取 [概觀] 索引標籤,然後選取 [資源群組] 底下的連結。
若要從儀表板移至該頁面,請選取 [資源群組],然後選取您用於本文的資源群組。
在 [資源群組] 分頁中,檢閱包含資源的清單,並確認這些是您想要刪除的項目。
選取 [刪除資源群組],並遵循指示。
刪除作業可能需要幾分鐘。 完成時,通知會出現幾秒鐘的時間。 您也可以選取分頁頂端的鈴鐺圖示以檢視通知。
下一步
您已建立了函式,並讓它在 Blob 儲存體中有 Blob 新增或更新時執行。 如需 Blob 儲存體觸發程序的詳細資訊,請參閱 Azure Functions Blob 儲存體繫結。
既然您已建立第一個函式,讓我們將輸出繫結新增至函式,以將訊息寫入儲存體佇列。