Doorvoer over partities opnieuw distribueren
VAN TOEPASSING OP: MongoDB
Standaard distribueert Azure Cosmos DB de ingerichte doorvoer van een database of container gelijkmatig over alle fysieke partities. Scenario's kunnen zich echter voordoen als gevolg van een scheeftrekken in de werkbelasting of de keuze van de partitiesleutel, bepaalde logische (en dus fysieke) partities meer doorvoer nodig hebben dan andere partities. Voor deze scenario's biedt Azure Cosmos DB u de mogelijkheid om uw ingerichte doorvoer opnieuw te distribueren over fysieke partities. Het opnieuw distribueren van doorvoer tussen partities helpt u betere prestaties te bereiken zonder dat u uw totale doorvoer hoeft te configureren op basis van de heetste partitie.
De functie voor het opnieuw distribueren van doorvoer is van toepassing op databases en containers met behulp van ingerichte doorvoer (handmatig en automatisch schalen) en is niet van toepassing op serverloze containers. U kunt de doorvoer per fysieke partitie wijzigen met behulp van de Azure Cosmos DB PowerShell- of Azure CLI-opdrachten.
Wanneer u deze functie gebruikt
Over het algemeen wordt het gebruik van deze functie aanbevolen voor scenario's waarin beide waar zijn:
- U ziet consistent 100% genormaliseerd gebruik op enkele partities van een verzameling.
- U ziet consistent een hogere latentie dan acceptatie.
Als u geen 100% RU-verbruik ziet en de end-to-endlatentie acceptabel is, is er geen actie nodig om RU/s per partitie opnieuw te configureren.
Als u een workload hebt die consistent verkeer heeft met af en toe onvoorspelbare pieken in al uw partities, is het raadzaam om automatische schaalaanpassing en burst-capaciteit te gebruiken. Automatische schaalaanpassing en burst-capaciteit zorgen ervoor dat u aan uw doorvoervereisten kunt voldoen. Als u een kleine hoeveelheid RU/s per partitie hebt, kunt u de partitiesamenvoeging ook gebruiken om het aantal partities te verminderen en ervoor te zorgen dat er meer RU/s per partitie zijn voor dezelfde totale ingerichte doorvoer.
Voorbeeldscenario
Stel dat we een workload hebben die transacties bijhoudt die plaatsvinden in winkels. Omdat de meeste van onze query's door StoreId
zijn, partitioneren we op StoreId
. Na verloop van tijd zien we echter dat sommige winkels meer activiteit hebben dan andere winkels en dat er meer doorvoer nodig is om hun workloads te verwerken. We zien 100% genormaliseerd ru-verbruik voor aanvragen op basis van deze StoreIds. Ondertussen zijn andere winkels minder actief en vereisen ze minder doorvoer. Laten we eens kijken hoe we onze doorvoer opnieuw kunnen distribueren voor betere prestaties.
Stap 1: bepalen welke fysieke partities meer doorvoer nodig hebben
Er zijn twee manieren om te bepalen of er een dynamische partitie is.
Optie 1: Metrische gegevens van Azure Monitor gebruiken
Als u wilt controleren of er een dynamische partitie is, gaat u naar Genormaliseerd RU-verbruik voor inzichten>>(%) op PartitionKeyRangeID. Filteren op een specifieke database en container.
Elke PartitionKeyRangeId wordt toegewezen aan één fysieke partitie. Zoek naar één PartitionKeyRangeId die consistent een hoger genormaliseerd RU-verbruik heeft dan andere. Eén waarde is bijvoorbeeld consistent op 100%, maar andere waarden zijn 30% of minder. Een patroon zoals dit kan duiden op een dynamische partitie.
Optie 2: Diagnostische logboeken gebruiken
We kunnen de informatie van CDBPartitionKeyRUConsumption in diagnostische logboeken gebruiken voor meer informatie over de logische partitiesleutels (en bijbehorende fysieke partities) die de meeste RU/s op een tweede niveau granulariteit gebruiken. Houd er rekening mee dat de voorbeeldquery's slechts 24 uur voor illustratieve doeleinden gebruiken. Het is raadzaam om ten minste zeven dagen geschiedenis te gebruiken om het patroon te begrijpen.
Zoek de fysieke partitie (PartitionKeyRangeId) die de meeste RU/s in de loop van de tijd verbruikt
CDBPartitionKeyRUConsumption
| where TimeGenerated >= ago(24hr)
| where DatabaseName == "MyDB" and CollectionName == "MyCollection" // Replace with database and collection name
| where isnotempty(PartitionKey) and isnotempty(PartitionKeyRangeId)
| summarize sum(RequestCharge) by bin(TimeGenerated, 1m), PartitionKeyRangeId
| render timechart
Voor een bepaalde fysieke partitie zoekt u de tien belangrijkste logische partitiesleutels die de meeste RU/s per uur gebruiken
CDBPartitionKeyRUConsumption
| where TimeGenerated >= ago(24hour)
| where DatabaseName == "MyDB" and CollectionName == "MyCollection" // Replace with database and collection name
| where isnotempty(PartitionKey) and isnotempty(PartitionKeyRangeId)
| where PartitionKeyRangeId == 0 // Replace with PartitionKeyRangeId
| summarize sum(RequestCharge) by bin(TimeGenerated, 1hour), PartitionKey
| order by sum_RequestCharge desc | take 10
Stap 2: de doel-RU/s voor elke fysieke partitie bepalen
Huidige RU/s voor elke fysieke partitie bepalen
Laten we eerst de huidige RU/s voor elke fysieke partitie bepalen. U kunt de metrische gegevens physicalPartitionThroughput van Azure Monitor gebruiken en splitsen door de dimensie PhysicalPartitionId om te zien hoeveel RU/s u per fysieke partitie hebt.
Als u de doorvoer per partitie nog niet eerder hebt gewijzigd, kunt u de formule ook gebruiken: Current RU/s per partition = Total RU/s / Number of physical partitions
Volg de richtlijnen in het artikel Aanbevolen procedures voor het schalen van ingerichte doorvoer (RU/s) om het aantal fysieke partities te bepalen.
U kunt ook de PowerShell Get-AzCosmosDBSqlContainerPerPartitionThroughput
en Get-AzCosmosDBMongoDBCollectionPerPartitionThroughput
opdrachten gebruiken om de huidige RU/s op elke fysieke partitie te lezen.
Gebruik Install-Module
deze optie om de Az.CosmosDB-module te installeren waarvoor functies voor voorlopige versies zijn ingeschakeld.
$parameters = @{
Name = "Az.CosmosDB"
AllowPrerelease = $true
Force = $true
}
Install-Module @parameters
Gebruik de Get-AzCosmosDBMongoDBCollectionPerPartitionThroughput
opdracht om de huidige RU/s op elke fysieke partitie te lezen.
// Container with dedicated RU/s
$somePartitionsDedicatedRUContainer = Get-AzCosmosDBMongoDBCollectionPerPartitionThroughput `
-ResourceGroupName "<resource-group-name>" `
-AccountName "<cosmos-account-name>" `
-DatabaseName "<cosmos-database-name>" `
-Name "<cosmos-collection-name>" `
-PhysicalPartitionIds ("<PartitionId>", "<PartitionId">, ...)
$allPartitionsDedicatedRUContainer = Get-AzCosmosDBMongoDBCollectionPerPartitionThroughput `
-ResourceGroupName "<resource-group-name>" `
-AccountName "<cosmos-account-name>" `
-DatabaseName "<cosmos-database-name>" `
-Name "<cosmos-collection-name>" `
-AllPartitions
// Database with shared RU/s
$somePartitionsSharedThroughputDatabase = Get-AzCosmosDBMongoDBDatabasePerPartitionThroughput `
-ResourceGroupName "<resource-group-name>" `
-AccountName "<cosmos-account-name>" `
-DatabaseName "<cosmos-database-name>" `
-PhysicalPartitionIds ("<PartitionId>", "<PartitionId">)
$allPartitionsSharedThroughputDatabase = Get-AzCosmosDBMongoDBDatabasePerPartitionThroughput `
-ResourceGroupName "<resource-group-name>" `
-AccountName "<cosmos-account-name>" `
-DatabaseName "<cosmos-database-name>" `
-AllPartitions
RU/s bepalen voor doelpartitie
Vervolgens gaan we bepalen hoeveel RU/s we willen geven aan de heetste fysieke partitie(s). We noemen deze set onze doelpartitie(s). De meeste RU/s elke fysieke partitie kan 10.000 RU/s bevatten.
De juiste benadering is afhankelijk van uw workloadvereisten. Algemene benaderingen zijn onder andere:
- Verhoog de RU/s met 10 procent en herhaal deze totdat de gewenste doorvoer is bereikt.
- Als u het juiste percentage niet zeker weet, kunt u beginnen met 10% om conservatief te zijn.
- Als u al weet dat voor deze fysieke partitie de meeste doorvoer van de workload is vereist, kunt u beginnen door de RU/s te verdubbelen of te verhogen tot het maximum van 10.000 RU/s, afhankelijk van wat lager is.
RU/s bepalen voor bronpartitie
Ten slotte gaan we bepalen hoeveel RU/s we willen behouden op onze andere fysieke partities. Deze selectie bepaalt de partities waaruit de fysieke doelpartitie doorvoer neemt.
In de PowerShell-API's moeten we ten minste één bronpartitie opgeven om RU/s opnieuw te distribueren. We kunnen ook een aangepaste minimale doorvoer opgeven die elke fysieke partitie moet hebben na de herdistributie. Als dit niet is opgegeven, zorgt Azure Cosmos DB er standaard voor dat elke fysieke partitie ten minste 100 RU/s heeft na de herdistributie. Het wordt aanbevolen om expliciet de minimale doorvoer op te geven.
De juiste benadering is afhankelijk van uw workloadvereisten. Algemene benaderingen zijn onder andere:
- Ru/s even gebruiken van alle bronpartities (werkt het beste als er = 10 partities zijn <)
- Bereken de hoeveelheid die we nodig hebben om elke fysieke bronpartitie te compenseren.
Offset = Total desired RU/s of target partition(s) - total current RU/s of target partition(s)) / (Total physical partitions - number of target partitions)
- De minimale doorvoer toewijzen voor elke bronpartitie =
Current RU/s of source partition - offset
- Bereken de hoeveelheid die we nodig hebben om elke fysieke bronpartitie te compenseren.
- RU/s nemen van de minst actieve partitie(s)
- Metrische gegevens en diagnostische logboeken van Azure Monitor gebruiken om te bepalen welke fysieke partities het minste verkeer/aanvraagvolume hebben
- Bereken de hoeveelheid die we nodig hebben om elke fysieke bronpartitie te compenseren.
Offset = Total desired RU/s of target partition(s) - total current RU/s of target partition) / Number of source physical partitions
- De minimale doorvoer toewijzen voor elke bronpartitie =
Current RU/s of source partition - offset
Stap 3: De doorvoer via een programma wijzigen tussen partities
U kunt de PowerShell-opdracht Update-AzCosmosDBSqlContainerPerPartitionThroughput
gebruiken om doorvoer opnieuw te distribueren.
Als u het onderstaande voorbeeld wilt begrijpen, gaan we een voorbeeld nemen van een container met 6000 RU/s totaal (ofwel 6000 handmatige RU/s of automatische schaalaanpassing van 6000 RU/s) en 3 fysieke partities. Op basis van onze analyse willen we een indeling waarin:
- Fysieke partitie 0: 1000 RU/s
- Fysieke partitie 1: 4000 RU/s
- Fysieke partitie 2: 1000 RU/s
We geven partities 0 en 2 op als onze bronpartities en geven aan dat ze na de herdistributie minimaal RU/s van 1000 RU/s moeten hebben. Partitie 1 is buiten de doelpartitie, die we opgeven moet 4000 RU/s hebben.
Gebruik voor Update-AzCosmosDBMongoDBCollectionPerPartitionThroughput
verzamelingen met toegewezen RU/s of de Update-AzCosmosDBMongoDBDatabasePerPartitionThroughput
opdracht voor databases met gedeelde RU/s om doorvoer over fysieke partities opnieuw te distribueren. In gedeelde doorvoerdatabases worden de id's van de fysieke partities vertegenwoordigd door een GUID-tekenreeks.
$SourcePhysicalPartitionObjects = @()
$SourcePhysicalPartitionObjects += New-AzCosmosDBPhysicalPartitionThroughputObject -Id "0" -Throughput 1000
$SourcePhysicalPartitionObjects += New-AzCosmosDBPhysicalPartitionThroughputObject -Id "2" -Throughput 1000
$TargetPhysicalPartitionObjects = @()
$TargetPhysicalPartitionObjects += New-AzCosmosDBPhysicalPartitionThroughputObject -Id "1" -Throughput 4000
// Collection with dedicated RU/s
Update-AzCosmosDBMongoDBCollectionPerPartitionThroughput `
-ResourceGroupName "<resource-group-name>" `
-AccountName "<cosmos-account-name>" `
-DatabaseName "<cosmos-database-name>" `
-Name "<cosmos-collection-name>" `
-SourcePhysicalPartitionThroughputObject $SourcePhysicalPartitionObjects `
-TargetPhysicalPartitionThroughputObject $TargetPhysicalPartitionObjects
// Database with shared RU/s
Update-AzCosmosDBMongoDBDatabasePerPartitionThroughput `
-ResourceGroupName "<resource-group-name>" `
-AccountName "<cosmos-account-name>" `
-DatabaseName "<cosmos-database-name>" `
-SourcePhysicalPartitionThroughputObject $SourcePhysicalPartitionObjects `
-TargetPhysicalPartitionThroughputObject $TargetPhysicalPartitionObjects
Nadat u de herdistributie hebt voltooid, kunt u de wijziging controleren door de metrische gegevens PhysicalPartitionThroughput in Azure Monitor weer te geven. Splits op de dimensie PhysicalPartitionId om te zien hoeveel RU/s u per fysieke partitie hebt.
Indien nodig kunt u de RU/s per fysieke partitie ook opnieuw instellen, zodat de RU/s van uw container gelijkmatig worden verdeeld over alle fysieke partities.
Gebruik de Update-AzCosmosDBMongoDBCollectionPerPartitionThroughput
opdracht voor verzamelingen met toegewezen RU/s of de Update-AzCosmosDBMongoDBDatabasePerPartitionThroughput
opdracht voor databases met gedeelde RU/s met parameter -EqualDistributionPolicy
om RU/s gelijkmatig over alle fysieke partities te distribueren.
// Collection with dedicated RU/s
Update-AzCosmosDBMongoDBCollectionPerPartitionThroughput `
-ResourceGroupName "<resource-group-name>" `
-AccountName "<cosmos-account-name>" `
-DatabaseName "<cosmos-database-name>" `
-Name "<cosmos-collection-name>" `
-EqualDistributionPolicy
// Database with shared RU/s
Update-AzCosmosDBMongoDBDatabasePerPartitionThroughput `
-ResourceGroupName "<resource-group-name>" `
-AccountName "<cosmos-account-name>" `
-DatabaseName "<cosmos-database-name>" `
-EqualDistributionPolicy
Stap 4: Uw RU/s-verbruik controleren en bewaken
Nadat u de herdistributie hebt voltooid, kunt u de wijziging controleren door de metrische gegevens PhysicalPartitionThroughput in Azure Monitor weer te geven. Splits op de dimensie PhysicalPartitionId om te zien hoeveel RU/s u per fysieke partitie hebt.
Het wordt aanbevolen om uw genormaliseerd ru-verbruik per partitie te bewaken. Raadpleeg stap 1 voor meer informatie om te controleren of u de verwachte prestaties hebt bereikt.
Nadat de wijzigingen zijn doorgevoerd, ervan uitgaande dat de algehele workload niet is gewijzigd, zult u waarschijnlijk zien dat zowel de fysieke doel- als de bronpartitie een hoger genormaliseerd RU-verbruik hebben dan eerder. Een hoger genormaliseerd RU-verbruik wordt verwacht. In wezen hebt u RU/s dichter bij wat elke partitie daadwerkelijk moet gebruiken, dus hoger genormaliseerd RU-verbruik betekent dat elke partitie volledig gebruikmaakt van de toegewezen RU/s. U zou ook een lagere algemene snelheid van 429 uitzonderingen moeten zien, omdat de dynamische partities nu meer RU/s hebben voor het verwerken van aanvragen.
Beperkingen
Criteria voor geschiktheid voor preview
Als u de preview wilt gebruiken, moet uw Azure Cosmos DB-account voldoen aan alle volgende criteria:
- Uw Azure Cosmos DB-account maakt gebruik van API voor MongoDB.
- De versie moet = 3.6 zijn >.
- Uw Cosmos-account maakt gebruik van de ingerichte doorvoer (handmatige of automatische schaalaanpassing). De distributie van doorvoer tussen partities is niet van toepassing op serverloze accounts.
U hoeft zich niet te registreren om de preview te gebruiken. Als u de functie wilt gebruiken, gebruikt u de PowerShell- of Azure CLI-opdrachten om de doorvoer over de fysieke partities van uw resources opnieuw te distribueren.
Volgende stappen
Meer informatie over het gebruik van ingerichte doorvoer met de volgende artikelen:
- Meer informatie over ingerichte doorvoer.
- Meer informatie over aanvraageenheden.
- Wilt u controleren op dynamische partities? Zie bewakingsaanvraageenheden.
- Wilt u de aanbevolen procedures leren? Zie de aanbevolen procedures voor het schalen van ingerichte doorvoer.
- Meer informatie over fouten met snelheidsbeperking