다음을 통해 공유


빠른 시작: Azure Functions 앱에 기능 플래그 추가

이 빠른 시작에서는 Azure Functions 앱을 만들고 그 안에 기능 플래그를 사용합니다. Azure App Configuration의 기능 관리를 사용하여 중앙에서 모든 기능 플래그를 저장하고 상태를 제어합니다.

필수 구성 요소

기능 플래그 추가

App Configuration 저장소에 베타라는 기능 플래그를 추가하고 레이블설명을 기본값으로 둡니다. Azure Portal 또는 CLI를 사용하여 저장소에 기능 플래그를 추가하는 방법에 대한 자세한 내용은 기능 플래그 만들기로 이동하세요.

Beta라는 기능 플래그 사용

함수 앱 만들기

Azure Functions (C#) 템플릿을 선택하여 Visual Studio를 사용하여 Azure Functions 앱을 만듭니다. 이 템플릿은 프로젝트에 대한 필수 설정을 구성하는 방법을 안내합니다. 자세한 지침은 Visual Studio를 사용하여 Azure Functions 개발을 참조하세요.

함수 앱을 만들 때 키 매개 변수에 대한 참조로 다음 표를 사용합니다.

설정
Functions 작업자 .NET 8.0 독립 실행
기능 HTTP 트리거
권한 부여 수준 익명

참고

Azure App Configuration은 격리된 작업자 모델 또는 In-process 모델에서 Azure Functions와 함께 사용할 수 있습니다. 이 빠른 시작에서는 격리된 작업자 모델을 예로 사용합니다. Azure App Configuration GitHub 리포지토리에서 두 모델에 대한 전체 코드 예제를 찾을 수 있습니다.

App Configuration 저장소에 연결

Microsoft Entra ID(권장) 또는 연결 문자열을 사용하여 App Configuration 저장소에 연결할 수 있습니다.

  1. 마우스 오른쪽 단추로 프로젝트를 클릭하고, NuGet 패키지 관리를 선택합니다. 찾아보기 탭에서 안정적인 최신 버전의 다음 NuGet 패키지를 검색하여 프로젝트에 추가합니다.

    • Microsoft.Azure.AppConfiguration.Functions.Worker
    • Microsoft.FeatureManagement
    • Azure.아이덴티티
  2. Program.cs 열고 다음과 같이 코드를 업데이트합니다. 메서드를 호출하여 Azure App Configuration을 추가 구성 원본으로 추가합니다 AddAzureAppConfiguration .

    DefaultAzureCredential을(를) 사용하여 App Configuration 저장소에 인증합니다. 지침에 따라 자격 증명에 App Configuration Data Reader 역할을 할당합니다. 애플리케이션을 실행하기 전에 권한이 전파될 수 있는 충분한 시간을 허용해야 합니다.

    using Azure.Identity;
    using Microsoft.Azure.Functions.Worker.Builder;
    using Microsoft.Extensions.Configuration;
    using Microsoft.Extensions.Hosting;
    using Microsoft.FeatureManagement;
    
    var builder = FunctionsApplication.CreateBuilder(args);
    
    // Connect to Azure App Configuration
    builder.Configuration.AddAzureAppConfiguration(options =>
    {
        Uri endpoint = new(Environment.GetEnvironmentVariable("AZURE_APPCONFIG_ENDPOINT") ?? 
            throw new InvalidOperationException("The environment variable 'AZURE_APPCONFIG_ENDPOINT' is not set or is empty."));
        options.Connect(endpoint, new DefaultAzureCredential())
               // Load all feature flags with no label. To load feature flags with specific keys and labels, set via FeatureFlagOptions.Select.
               // Use the default refresh interval of 30 seconds. It can be overridden via FeatureFlagOptions.SetRefreshInterval.
               .UseFeatureFlags();
    });
    

    이 메서드는 UseFeatureFlags() 공급자에게 기능 플래그를 로드하도록 지시합니다. 기본적으로 레이블이 없는 모든 기능 플래그는 30초마다 로드되고 새로 고쳐집니다. 기능 플래그의 선택 및 새로 고침 동작은 다른 구성 키 값과 독립적으로 구성됩니다. 메서드에 FeatureFlagOptions 작업을 전달하여 UseFeatureFlags 동작을 사용자 지정할 수 있습니다. FeatureFlagOptions.Select를 사용하여 로드할 기능 플래그의 키와 레이블을 지정하고, FeatureFlagOptions.SetRefreshInterval를 사용하여 기본 새로 고침 간격을 재정의합니다.

    기능 플래그 이외의 구성이 애플리케이션에 로드되는 것을 원하지 않는 경우 options.Select("_")를 호출하여 존재하지 않는 더미 키 "_"만 로드할 수 있습니다. 기본적으로 Select 메서드가 호출되지 않으면 App Configuration 저장소에서 레이블이 없는 모든 구성 키 값이 로드됩니다.

  3. Azure App Configuration 미들웨어를 추가하여 각 함수 실행에서 자동 기능 플래그 새로 고침을 사용하도록 Program.cs 파일을 업데이트합니다. 또한 기능 관리 서비스를 등록하여 나중에 함수 코드에 삽입하고 사용할 수 있습니다.

    // Connect to Azure App Configuration
    builder.Configuration.AddAzureAppConfiguration(options =>
    {
        // Omitted the code added in the previous step.
    });
    
    // Add Azure App Configuration middleware and feature management to the service collection.
    builder.Services
        .AddAzureAppConfiguration()
        .AddFeatureManagement();
    
    // Use Azure App Configuration middleware for dynamic configuration and feature flag refresh.
    builder.UseAzureAppConfiguration();
    
    builder.ConfigureFunctionsWebApplication();
    
    builder.Build().Run();
    
  4. Function1.cs 열고 다음 네임스페이스를 추가합니다.

    using Microsoft.FeatureManagement;
    

    종속성 주입을 통해 인스턴스 IVariantFeatureManagerSnapshot 를 가져오도록 생성자를 업데이트합니다.

    private readonly IVariantFeatureManagerSnapshot _featureManager;
    private readonly ILogger<Function1> _logger;
    
    public Function1(IVariantFeatureManagerSnapshot featureManager, ILogger<Function1> logger)
    {
        _featureManager = featureManager;
        _logger = logger;
    }
    
  5. 기능 플래그의 Run 상태에 따라 응답 메시지를 반환하도록 메서드를 업데이트합니다.

    [Function("Function1")]
    public async Task<IActionResult> Run([HttpTrigger(AuthorizationLevel.Anonymous, "get", "post")] HttpRequest req)
    {
        _logger.LogInformation("C# HTTP trigger function processed a request.");
    
        // Read feature flag
        string featureName = "Beta";
        bool featureEnabled = await _featureManager.IsEnabledAsync(featureName, req.HttpContext.RequestAborted);
    
        return new OkObjectResult(featureEnabled
            ? $"The Feature Flag '{featureName}' is turned ON!"
            : $"The Feature Flag '{featureName}' is turned OFF");
    }
    

로컬에서 함수 테스트

  1. 환경 변수를 설정합니다.

    AZURE_APPCONFIG_ENDPOINT 환경 변수를 Azure Portal의 저장소 개요 아래에 있는 App Configuration 저장소의 엔드포인트로 설정합니다.

    Windows 명령 프롬프트를 사용하는 경우 다음 명령을 실행하고, 명령 프롬프트를 다시 시작하여 변경 내용을 적용합니다.

    setx AZURE_APPCONFIG_ENDPOINT "<endpoint-of-your-app-configuration-store>"
    

    PowerShell을 사용하는 경우 다음 명령을 실행합니다.

    $Env:AZURE_APPCONFIG_ENDPOINT = "<endpoint-of-your-app-configuration-store>"
    

    macOS 또는 Linux를 사용하는 경우 다음 명령을 실행합니다.

    export AZURE_APPCONFIG_ENDPOINT='<endpoint-of-your-app-configuration-store>'
    
  2. F5를 눌러 함수를 테스트합니다. 메시지가 표시되면 Visual Studio에서 Azure Functions Core(CLI) 도구를 다운로드하여 설치하도록 요구하는 요청을 수락합니다. 또한 도구에서 HTTP 요청을 처리할 수 있도록 방화벽 예외를 사용하도록 설정해야 할 수도 있습니다.

  3. Azure Functions 런타임 출력에서 함수의 URL을 복사합니다.

    VS에서 빠른 시작 함수 디버깅

  4. HTTP 요청에 대한 URL을 브라우저의 주소 표시줄에 붙여 넣습니다. 다음 이미지는 기능 플래그 베타가 비활성화되었음을 나타내는 응답을 보여줍니다.

    빠른 시작 함수 기능 플래그 사용 안 함

  5. Azure Portal에서 App Configuration 저장소로 이동합니다. 작업에서 기능 관리자를 선택한 후 베타 기능 플래그를 찾아 사용 토글을 켜짐으로 설정합니다.

  6. 브라우저를 몇 번 새로 고칩니다. 새로 고침 간격 시간 창이 지나면 이미지와 같이 기능 플래그 베타 가 켜져 있음을 나타내기 위해 페이지가 변경됩니다.

    빠른 시작 함수 기능 플래그 사용

리소스 정리

이 문서에서 만든 리소스를 계속 사용하지 않으려면 여기서 만든 리소스 그룹을 삭제하여 요금이 부과되지 않도록 합니다.

중요합니다

리소스 그룹을 삭제하면 다시 되돌릴 수 없습니다. 리소스 그룹 및 포함된 모든 리소스가 영구적으로 삭제됩니다. 잘못된 리소스 그룹 또는 리소스를 자동으로 삭제하지 않도록 합니다. 유지하려는 다른 리소스가 포함된 리소스 그룹 내에서 이 문서에 대한 리소스를 만든 경우 리소스 그룹을 삭제하는 대신 해당 창에서 각 리소스를 개별적으로 삭제합니다.

  1. Azure Portal에 로그인하고 리소스 그룹을 선택합니다.
  2. 이름으로 필터링 상자에서 리소스 그룹의 이름을 입력합니다.
  3. 결과 목록에서 리소스 그룹 이름을 선택하여 개요를 확인합니다.
  4. 리소스 그룹 삭제를 선택합니다.
  5. 리소스 그룹 삭제를 확인하는 메시지가 표시됩니다. 리소스 그룹의 이름을 입력하여 확인하고 삭제를 선택합니다.

잠시 후, 리소스 그룹 및 모든 해당 리소스가 삭제됩니다.

다음 단계

이 빠른 시작에서는 기능 플래그를 만들고 Azure Functions 앱과 함께 사용했습니다.

.NET 기능 관리 라이브러리의 전체 기능 요약을 보려면 다음 문서를 계속 진행합니다.

Azure App Configuration에서 기능 플래그를 관리하는 방법에 대해 자세히 알아보려면 다음 자습서를 계속 진행합니다.