Hantera Batch-konton och kvoter med Batch Management-klientbiblioteket för .NET
Du kan minska underhållskostnaderna i dina Azure Batch-program med hjälp av Batch Management .NET-biblioteket för att automatisera skapande, borttagning, nyckelhantering och kvotidentifiering i Batch-kontot.
- Skapa och ta bort Batch-konton inom valfri region. Om du till exempel som oberoende programvaruleverantör (ISV) tillhandahåller en tjänst för dina klienter där var och en tilldelas ett separat Batch-konto i faktureringssyfte, kan du lägga till funktioner för att skapa och ta bort konton i kundportalen.
- Hämta och återskapa kontonycklar programmatiskt för något av dina Batch-konton. Detta kan hjälpa dig att följa säkerhetsprinciper som framtvingar regelbunden återställning eller förfallodatum för kontonycklar. När du har flera Batch-konton i olika Azure-regioner ökar automatiseringen av den här rollover-processen lösningens effektivitet.
- Kontrollera kontokvoterna och ta bort gissningen om utvärdering och fel för att avgöra vilka Batch-konton som har vilka gränser. Genom att kontrollera dina kontokvoter innan du startar jobb, skapar pooler eller lägger till beräkningsnoder kan du proaktivt justera var eller när dessa beräkningsresurser skapas. Du kan avgöra vilka konton som kräver kvotökningar innan du allokerar ytterligare resurser i dessa konton.
- Kombinera funktioner i andra Azure-tjänster för en fullständig hanteringsupplevelse med hjälp av Batch Management .NET, Microsoft Entra ID och Azure Resource Manager tillsammans i samma program. Genom att använda dessa funktioner och deras API:er kan du tillhandahålla en friktionsfri autentiseringsupplevelse, möjligheten att skapa och ta bort resursgrupper och de funktioner som beskrivs ovan för en hanteringslösning från slutpunkt till slutpunkt.
Kommentar
Den här artikeln fokuserar på programmatisk hantering av batchkonton, nycklar och kvoter, men du kan också utföra många av dessa aktiviteter med hjälp av Azure Portal.
Skapa och ta bort Batch-konton
En av de viktigaste funktionerna i Batch Management-API:et är att skapa och ta bort Batch-konton i en Azure-region. Det gör du genom att använda BatchAccountCollection.CreateOrUpdate och Delete, eller deras asynkrona motsvarigheter.
Följande kodfragment skapar ett konto, hämtar det nyligen skapade kontot från Batch-tjänsten och tar sedan bort det.
string subscriptionId = "Your SubscriptionID";
string resourceGroupName = "Your ResourceGroup name";
var credential = new DefaultAzureCredential();
ArmClient _armClient = new ArmClient(credential);
ResourceIdentifier resourceGroupResourceId = ResourceGroupResource.CreateResourceIdentifier(subscriptionId, resourceGroupName);
ResourceGroupResource resourceGroupResource = _armClient.GetResourceGroupResource(resourceGroupResourceId);
var data = new BatchAccountCreateOrUpdateContent(AzureLocation.EastUS);
// Create a new batch account
resourceGroupResource.GetBatchAccounts().CreateOrUpdate(WaitUntil.Completed, "Your BatchAccount name", data);
// Get an existing batch account
BatchAccountResource batchAccount = resourceGroupResource.GetBatchAccount("Your BatchAccount name");
// Delete the batch account
batchAccount.Delete(WaitUntil.Completed);
Kommentar
Program som använder Batch Management .NET-biblioteket kräver tjänstadministratör eller medadministratörsåtkomst till den prenumeration som äger Batch-kontot som ska hanteras. Mer information finns i avsnittet Microsoft Entra-ID och kodexemplet AccountManagement .
Hämta och återskapa kontonycklar
Hämta primära och sekundära kontonycklar från valfritt Batch-konto i din prenumeration med hjälp av GetKeys. Du kan återskapa dessa nycklar med hjälp av RegenerateKey.
string subscriptionId = "Your SubscriptionID";
string resourceGroupName = "Your ResourceGroup name";
var credential = new DefaultAzureCredential();
ArmClient _armClient = new ArmClient(credential);
ResourceIdentifier resourceGroupResourceId = ResourceGroupResource.CreateResourceIdentifier(subscriptionId, resourceGroupName);
ResourceGroupResource resourceGroupResource = _armClient.GetResourceGroupResource(resourceGroupResourceId);
var data = new BatchAccountCreateOrUpdateContent(AzureLocation.EastUS);
// Get an existing batch account
BatchAccountResource batchAccount = resourceGroupResource.GetBatchAccount("Your BatchAccount name");
// Get and print the primary and secondary keys
BatchAccountKeys accountKeys = batchAccount.GetKeys();
Console.WriteLine("Primary key: {0}", accountKeys.Primary);
Console.WriteLine("Secondary key: {0}", accountKeys.Secondary);
// Regenerate the primary key
BatchAccountRegenerateKeyContent regenerateKeyContent = new BatchAccountRegenerateKeyContent(BatchAccountKeyType.Primary);
batchAccount.RegenerateKey(regenerateKeyContent);
Dricks
Du kan skapa ett effektiviserat anslutningsarbetsflöde för dina hanteringsprogram. Hämta först en kontonyckel för det Batch-konto som du vill hantera med GetKeys. Använd sedan den här nyckeln när du initierar Batch .NET-bibliotekets BatchSharedKeyCredentials-klass , som används vid initiering av BatchClient.
Kontrollera kvoter för Azure-prenumeration och Batch-konto
Azure-prenumerationer och enskilda Azure-tjänster som Batch har alla standardkvoter som begränsar antalet vissa entiteter i dem. Standardkvoter för Azure-prenumerationer finns i Azure-prenumerations - och tjänstgränser, kvoter och begränsningar. Standardkvoter för Batch-tjänsten finns i Kvoter och gränser för Azure Batch-tjänsten. Med hjälp av Batch Management .NET-biblioteket kan du kontrollera dessa kvoter i dina program. På så sätt kan du fatta allokeringsbeslut innan du lägger till konton eller beräkningsresurser som pooler och beräkningsnoder.
Kontrollera en Azure-prenumeration för Batch-kontokvoter
Innan du skapar ett Batch-konto i en region kan du kontrollera din Azure-prenumeration för att se om du kan lägga till ett konto i den regionen.
I kodfragmentet nedan använder vi först GetBatchAccounts för att hämta en samling av alla Batch-konton som finns i en prenumeration. När vi har fått den här samlingen avgör vi hur många konton som finns i målregionen. Sedan använder vi GetBatchQuotas för att hämta Batch-kontokvoten och fastställa hur många konton (om några) som kan skapas i den regionen.
string subscriptionId = "Your SubscriptionID";
ArmClient _armClient = new ArmClient(new DefaultAzureCredential());
ResourceIdentifier subscriptionResourceId = SubscriptionResource.CreateResourceIdentifier(subscriptionId);
SubscriptionResource subscriptionResource = _armClient.GetSubscriptionResource(subscriptionResourceId);
// Get a collection of all Batch accounts within the subscription
var batchAccounts = subscriptionResource.GetBatchAccounts();
Console.WriteLine("Total number of Batch accounts under subscription id {0}: {1}", subscriptionId, batchAccounts.Count());
// Get a count of all accounts within the target region
string region = "eastus";
int accountsInRegion = batchAccounts.Count(o => o.Data.Location == region);
// Get the account quota for the specified region
BatchLocationQuota batchLocationQuota = subscriptionResource.GetBatchQuotas(AzureLocation.EastUS);
Console.WriteLine("Account quota for {0} region: {1}", region, batchLocationQuota.AccountQuota);
// Determine how many accounts can be created in the target region
Console.WriteLine("Accounts in {0}: {1}", region, accountsInRegion);
Console.WriteLine("You can create {0} accounts in the {1} region.", batchLocationQuota.AccountQuota - accountsInRegion, region);
I kodfragmentet ovan creds
är en instans av TokenCredentials. Ett exempel på hur du skapar det här objektet finns i kodexemplet AccountManagement på GitHub.
Kontrollera ett Batch-konto för beräkningsresurskvoter
Innan du ökar beräkningsresurserna i Batch-lösningen kan du kontrollera att de resurser som du vill allokera inte överskrider kontots kvoter. I kodfragmentet nedan skriver vi ut kvotinformationen för Batch-kontot med namnet mybatchaccount
. I ditt eget program kan du använda sådan information för att avgöra om kontot kan hantera de ytterligare resurser som ska skapas.
string subscriptionId = "Your SubscriptionID";
string resourceGroupName = "Your ResourceGroup name";
var credential = new DefaultAzureCredential();
ArmClient _armClient = new ArmClient(credential);
ResourceIdentifier resourceGroupResourceId = ResourceGroupResource.CreateResourceIdentifier(subscriptionId, resourceGroupName);
ResourceGroupResource resourceGroupResource = _armClient.GetResourceGroupResource(resourceGroupResourceId);
// Get an existing batch account
BatchAccountResource batchAccount = resourceGroupResource.GetBatchAccount("Your BatchAccount name");
// Now print the compute resource quotas for the account
Console.WriteLine("Core quota: {0}", batchAccount.Data.DedicatedCoreQuota);
Console.WriteLine("Pool quota: {0}", batchAccount.Data.PoolQuota);
Console.WriteLine("Active job and job schedule quota: {0}", batchAccount.Data.ActiveJobAndJobScheduleQuota);
Viktigt!
Det finns standardkvoter för Azure-prenumerationer och -tjänster, men många av dessa gränser kan höjas genom att begära en kvotökning i Azure Portal.
Använda Microsoft Entra-ID med Batch Management .NET
Batch Management .NET-biblioteket är en Azure-resursproviderklient och används tillsammans med Azure Resource Manager för att hantera kontoresurser programmatiskt. Microsoft Entra-ID krävs för att autentisera begäranden som görs via valfri Azure-resursproviderklient, inklusive Batch Management .NET-biblioteket och via Azure Resource Manager. Information om hur du använder Microsoft Entra-ID med Batch Management .NET-biblioteket finns i Använda Microsoft Entra-ID för att autentisera Batch-lösningar.
Exempelprojekt på GitHub
Om du vill se hur Batch Management .NET fungerar i praktiken kan du titta på exempelprojektet AccountManagement på GitHub. Exempelprogrammet AccountManagement visar följande åtgärder:
- Hämta en säkerhetstoken från Microsoft Entra-ID med hjälp av Hämta och cachelagra token med hjälp av Microsoft Authentication Library (MSAL). Om användaren inte redan är inloggad uppmanas de att ange sina Azure-autentiseringsuppgifter.
- Med säkerhetstoken som hämtats från Microsoft Entra-ID:t skapar du en SubscriptionClient för att fråga Azure om en lista över prenumerationer som är associerade med kontot. Användaren kan välja en prenumeration i listan om den innehåller mer än en prenumeration.
- Hämta autentiseringsuppgifter som är associerade med den valda prenumerationen.
- Skapa ett ResourceManagementClient-objekt med hjälp av autentiseringsuppgifterna.
- Använd ett ResourceManagementClient-objekt för att skapa en resursgrupp.
- Använd ett BatchManagementClient-objekt för att utföra flera Batch-kontoåtgärder:
- Skapa ett Batch-konto i den nya resursgruppen.
- Hämta det nyligen skapade kontot från Batch-tjänsten.
- Skriv ut kontonycklarna för det nya kontot.
- Återskapa en ny primärnyckel för kontot.
- Skriv ut kvotinformationen för kontot.
- Skriv ut kvotinformationen för prenumerationen.
- Skriv ut alla konton i prenumerationen.
- Ta bort det nyligen skapade kontot.
- Ta bort resursgruppen.
Om du vill köra exempelprogrammet måste du först registrera det med din Microsoft Entra-klientorganisation i Azure Portal och bevilja behörigheter till Azure Resource Manager-API:et. Följ stegen i Autentisera Batch Management-lösningar med Active Directory.
Nästa steg
- Lär dig mer om Batch-tjänstens arbetsflöde och primära resurser , till exempel pooler, noder, jobb och uppgifter.
- Lär dig hur du utvecklar ett enkelt Batch-aktiverat program med hjälp av Batch .NET-klientbiblioteket eller Python. De här snabbstarterna vägleder dig genom ett exempelprogram som använder Batch-tjänsten för att köra en arbetsbelastning på flera beräkningsnoder med hjälp av Azure Storage för mellanlagring och hämtning av arbetsbelastningsfiler.