Rychlý start: Přidání příznaků funkcí do služby na pozadí .NET
V tomto rychlém startu začleníte funkci správy funkcí z Aplikace Azure Konfigurace do služby .NET background. App Configuration slouží k centrálnímu ukládání a správě příznaků funkcí.
Požadavky
Podpora správy funkcí rozšiřuje funkci dynamické konfigurace v App Configuration. Příklad v tomto rychlém startu vychází z aplikace služby .NET background představené v kurzu dynamické konfigurace. Než budete pokračovat, dokončete následující kurz a nejprve vytvořte aplikaci služby na pozadí .NET s dynamickou konfigurací.
Přidání příznaku funkce
Přidejte příznak funkce s názvem Beta do obchodu App Configuration Store a ponechte popis a popis s výchozími hodnotami. Další informace o přidání příznaků funkcí do úložiště pomocí webu Azure Portal nebo rozhraní příkazového řádku najdete v části Vytvoření příznaku funkce.
Použití příznaku funkce
Přidejte odkazy na
Microsoft.FeatureManagement
balíček NuGet spuštěním následujícího příkazu:dotnet add package Microsoft.FeatureManagement
Spuštěním následujícího příkazu obnovte balíčky pro váš projekt:
dotnet restore
Otevřete Program.cs a přidejte následující příkaz:
using Microsoft.FeatureManagement;
Přidejte volání metody
UseFeatureFlags
uvnitřAddAzureAppConfiguration
volání a zaregistrujte služby správy funkcí.// Existing code in Program.cs // ... ... builder.Configuration.AddAzureAppConfiguration(options => { string endpoint = Environment.GetEnvironmentVariable("Endpoint"); options.Connect(new Uri(endpoint), new DefaultAzureCredential()); // Use feature flags options.UseFeatureFlags(); // Register the refresher so that the Worker service can consume it through dependency injection builder.Services.AddSingleton(options.GetRefresher()); }); // Register feature management services builder.Services.AddFeatureManagement(); // The rest of existing code in Program.cs // ... ...
Tip
Pokud metodě
UseFeatureFlags
není předán žádný parametr, načte všechny příznaky funkcí bez popisku v App Configuration Storu. Výchozí interval aktualizace příznaků funkcí je 30 sekund. Toto chování můžete přizpůsobit pomocí parametruFeatureFlagOptions
. Například následující fragment kódu načte pouze příznaky funkcí, které začínají testAppem: v názvu klíče a mají vývoj popisků. Kód také změní dobu intervalu aktualizace na 5 minut. Všimněte si, že tato doba intervalu aktualizace je oddělená od času pro běžné hodnoty klíče.options.UseFeatureFlags(featureFlagOptions => { featureFlagOptions.Select("TestApp:*", "dev"); featureFlagOptions.CacheExpirationInterval = TimeSpan.FromMinutes(5); });
Otevřete Worker.cs a přidejte následující příkaz:
using Microsoft.FeatureManagement;
Aktualizujte konstruktor
Worker
služby, aby získal instance injektáže závislostí aIVariantFeatureManager
prostřednictvím injektážeIConfigurationRefresher
závislostí.public class Worker : BackgroundService { private readonly ILogger<Worker> _logger; private readonly IConfigurationRefresher _refresher; private readonly IVariantFeatureManager _featureManager; public Worker(ILogger<Worker> logger, IConfigurationRefresher refresher, IVariantFeatureManager featureManager) { _logger = logger ?? throw new ArgumentNullException(nameof(logger)); _refresher = refresher ?? throw new ArgumentNullException(nameof(refresher)); _featureManager = featureManager ?? throw new ArgumentNullException(nameof(featureManager)); } // ... ... }
Aktualizujte metodu
ExecuteAsync
pro protokolování zprávy v závislosti na stavu příznaku funkce.Metoda
TryRefreshAsync
je volána na začátku každé iterace provádění úlohy pro aktualizaci příznaku funkce. Bude to no-op, pokud není dosaženo časového intervalu aktualizace. Operátorawait
se nepoužívá, aby se příznaky funkcí aktualizovaly bez blokování aktuální iterace provádění úlohy. V takovém případě se později iterace provádění úlohy získají aktualizovanou hodnotu.protected override async Task ExecuteAsync(CancellationToken stoppingToken) { while (!stoppingToken.IsCancellationRequested) { // Intentionally not await TryRefreshAsync to avoid blocking the execution. _refresher.TryRefreshAsync(stoppingToken); if (_logger.IsEnabled(LogLevel.Information)) { if (await _featureManager.IsEnabledAsync("Beta")) { _logger.LogInformation("[{time}]: Worker is running with Beta feature.", DateTimeOffset.Now); } else { _logger.LogInformation("[{time}]: Worker is running.", DateTimeOffset.Now); } } await Task.Delay(TimeSpan.FromSeconds(30), stoppingToken); } }
Sestavení a místní spuštění aplikace
Spuštěním následujícího příkazu sestavte aplikaci:
dotnet build
Po úspěšném dokončení sestavení spusťte aplikaci místně spuštěním následujícího příkazu:
dotnet run
V konzole by se měly zobrazit následující výstupy.
Přihlaste se k portálu Azure. Vyberte Všechny prostředky a vyberte obchod App Configuration, který jste vytvořili dříve.
Vyberte Správce funkcí a vyhledejte příznak funkce Beta . Povolte příznak zaškrtnutím políčka v části Povoleno.
Chvíli počkejte, než se časové období intervalu aktualizace prodá. Zobrazí se aktualizovaná zpráva protokolu.
Vyčištění prostředků
Pokud nechcete dál používat prostředky vytvořené v tomto článku, odstraňte skupinu prostředků, kterou jste tady vytvořili, abyste se vyhnuli poplatkům.
Důležité
Odstranění skupiny prostředků je nevratné. Skupina prostředků a všechny prostředky v ní se trvale odstraní. Ujistěte se, že omylem neodstraníte nesprávnou skupinu prostředků nebo prostředky. Pokud jste vytvořili prostředky pro tento článek ve skupině prostředků, která obsahuje další prostředky, které chcete zachovat, odstraňte jednotlivé prostředky z příslušného podokna místo odstranění skupiny prostředků.
- Přihlaste se k webu Azure Portal a vyberte skupiny prostředků.
- Do pole Filtrovat podle názvu zadejte název vaší skupiny prostředků.
- V seznamu výsledků vyberte název skupiny prostředků, abyste zobrazili přehled.
- Vyberte Odstranit skupinu prostředků.
- Zobrazí se výzva k potvrzení odstranění skupiny prostředků. Potvrďte název skupiny prostředků a vyberte Odstranit.
Po chvíli se skupina prostředků a všechny její prostředky odstraní.
Další kroky
V tomto rychlém startu jste vytvořili příznak funkce a použili ho se službou na pozadí.
Pokud chcete povolit funkci správy funkcí pro jiné typy aplikací, pokračujte následujícími kurzy.
Další informace o správě příznaků funkcí v konfiguraci Aplikace Azure najdete v následujícím kurzu.
Úplný běh funkcí knihovny pro správu funkcí .NET najdete v následujícím dokumentu.