2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

AzureFunctionsでローカルでAzure Blob Storage Triggerな環境構築を行う

Last updated at Posted at 2022-12-04

はじめに

前回の記事でHTTP TriggerなAzure Functionsを作成しました。
前回作成したものにAzure Blob Storage Triggerの機能を今回は追加したいと思います。

環境

  • Windows11
  • Visual Studio Code
  • Azure Functions Core Tools v4.0
  • Microsoft Azure Storage Explorer

①Azure Blob Storage Triggerを追加する

Azureマークをクリックしその後、WorkSpaceのFunctionマークをクリックします。
Func1.png

その後、以下を順にクリックしていきます。

  1. Azure Blob Storage trigger
  2. BlobTrigger1(機能名、今回はデフォルトのままです)
  3. Company.Function(namespace、今回はデフォルトのままです)
  4. AzureWebJobsStorage(local.settings.jsonになければ追加します。)
  5. samples-workitems(監視するストレージ名)

※4に関して補足

{
    "Values": {
        "AzureWebJobsStorage": "UseDevelopmentStorage=true",
    }
}

作成後はBlobTrigger1.csが追加されていると思います。
スクリーンショット 2022-12-04 213641.png

②Azure Blob Storage Triggerの稼働確認

  1. Ctrl + Shift + Pでコマンドパレットを開き「Azurite: Start」をクリックします。
  2. デバッグ実行します。(F5キー)
  3. Azure Storage Explorerを開き、エミュレータのBlobコンテナに「samples-workitems」コンテナを作成します。
  4. 作成後、適当なファイルをアップロードしてみます。
    ※今回はtest.txtというファイルをアップロードしてみました。
    image.png
    アップロード後、VSCodeのターミナルを確認すると以下のようなものが出力されていると思います。
    image.png

番外編:HTTP Triggerで受け取った文字列をBlobにアップロードし、さらにそれをAzure Blob Storage Triggerする

①Requestの文字列を取得しその文字列をBlobにアップロードする

※前回作成分に追記

Utility/AzureStorageClientUtility.cs
using System;
using System.Threading.Tasks;
using Azure;
using Azure.Storage.Blobs;

namespace Company.Function.Utility
{
    public class AzureStorageClientUtility
    {
        /// <summary>
        /// コンテナクライアント
        /// 接続文字列はAzuriteでのエミュレータ共有キー資格情報
        /// </summary>
        BlobServiceClient blobServiceClient = new BlobServiceClient("DefaultEndpointsProtocol=http;AccountName=devstoreaccount1;AccountKey=Eby8vdM02xNOcqFlqUwJPLlmEtlCDXJ1OUzFT50uSRZ6IFsuFq2UVErCz4I6tq/K1SZFPTOtr/KBHBeksoGMGw==;BlobEndpoint=http://127.0.0.1:10000/devstoreaccount1;");

        /// <summary>
        /// Blobに文字列をアップロードする
        /// 今回追加
        /// </summary>
        public async Task<BlobContainerClient> UploadFileAsync(string name)
        {
            BlobContainerClient containerClient = blobServiceClient.GetBlobContainerClient("samples-workitems");
            BlobClient blobClient = containerClient.GetBlobClient(name);
            await blobClient.UploadAsync(BinaryData.FromString(name), overwrite: true);
            return null;
        }
    }
}
HttpTrigger1.cs
using System;
using System.IO;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Azure.WebJobs;
using Microsoft.Azure.WebJobs.Extensions.Http;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.Logging;
using Newtonsoft.Json;
using Company.Function.Utility;

namespace Company.Function
{
    public static class HttpTrigger1
    {
        [FunctionName("HttpTrigger1")]
        public static async Task<IActionResult> Run(
            [HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)] HttpRequest req,
            ILogger log)
        {
            log.LogInformation("C# HTTP trigger function processed a request.");

            string name = req.Query["name"];

            string requestBody = await new StreamReader(req.Body).ReadToEndAsync();
            dynamic data = JsonConvert.DeserializeObject(requestBody);
            name = name ?? data?.name;

            string responseMessage = string.IsNullOrEmpty(name)
                ? "This HTTP triggered function executed successfully. Pass a name in the query string or in the request body for a personalized response."
                : $"Hello, {name}. This HTTP triggered function executed successfully.";

            // 今回追加
            AzureStorageClientUtility azureUtility = new AzureStorageClientUtility();
            if (!string.IsNullOrWhiteSpace(name))
            {
                await azureUtility.UploadFileAsync(name);
            }

            return new OkObjectResult(responseMessage);
        }
    }
}

②稼働確認

デバッグ実行し、APIRequestしてみる

Invoke-WebRequest -Uri "http://localhost:7071/api/HttpTrigger1" `
                  -Method POST `
                  -Headers @{"Content-Type"="application/json"} `
                  -Body "{'name':'hello world'}"

Azure Storage Explorerにファイルが作成されていることが確認できます。
image.png

アップロード後、VSCodeのターミナルを確認すると以下のようなものが出力されていると思います。
image.png

おまけ
# powershellバージョン要確認
1..10 | ForEach-Object -Parallel { Invoke-WebRequest -Uri "http://localhost:7071/api/HttpTrigger1" -Method POST  -Headers @{"Content-Type"="application/json"}  -Body "{'name':$_}" }

image.png
image.png

所感

今回は前回の機能に追加でローカルでAzure Blob Storage Triggerな環境構築を行いました。
まだまだAzure Functionsには機能があるので深堀していけたらよいなと思います。
今後もいろいろチャレンジしてみたいと思います。

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?