Tra i numerosi servizi PaaS offerti dalla piattaforma cloud di Microsoft, troviamo Cosmos DB, un database distribuito a livello globale con prestazioni garantite, capace di supportare il modello NoSQL, tabelle e grafi allo stesso tempo.
Quando usiamo il modello documentale è importante organizzare i propri grafi di oggetti partizionando le collezioni, al fine di migliorare l'allocazione, che non può superare i 10 GB, e di garantire lo scaling orizzontale. Nell'effettuare query sulle collezioni, possiamo ricercare per indici che non permettono una ricerca ottimizzata, qualora non l'arricchiamo indicando anche il campo di partizionamento, costringendo il motore a cercare in tutte le partizioni.
Questa situazione è inevitabile, ma possiamo migliorare le prestazioni di esecuzione della query andando a intervenire sul client disponibile con l'SDK. Sul metodo CreateDocumentQuery possiamo specificare tra le opzioni di eseguire le query in parallelo su più partizioni, come mostrato nell'esempio.
Uri uri = UriFactory.CreateDocumentCollectionUri("mydb", "products") // Personalizzo le opzioni var options = new FeedOptions { EnableCrossPartitionQuery = true, MaxDegreeOfParallelism = 10, MaxBufferedItemCount = 100 }; Product[] products = client.CreateDocumentQuery<Product>(uri, options) .Where(m => m.Price > 10) .OrderBy(m => m.Id) .ToArray()
Con MaxDegreeOfParallelism controlliamo quante connessioni contemporanee effettuare, riuscendo ad eseguire più query, mentre con MaxBufferedItemCount controlliamo quanti elementi riuscire a mettere in memoria, favorendo poi l'algoritmo che mette in ordine gli elementi ottenuti da ogni collezione. Chiaramente occorre trovare dei valori che non siano eccessivi dal punto di vista della rete e della ram allocata. Possiamo in alternativa lasciare i valori predefiniti e lasciare all'SDK la gestione.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Creare una libreria CSS universale: i bottoni
Creare una libreria CSS universale - Rotazione degli elementi
Recuperare App Service cancellati su Azure
Cancellare una run di un workflow di GitHub
Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
Migliorare i tempi di risposta di GPT tramite lo streaming endpoint in ASP.NET Core
Ordinare randomicamente una lista in C#
Potenziare la ricerca su Cosmos DB con Full Text Search
Autenticazione di git tramite Microsoft Entra ID in Azure DevOps
Configurare lo startup di applicazioni server e client con .NET Aspire
Gestire i dati con Azure Cosmos DB Data Explorer
I più letti di oggi
- Creare un router per Single Page Application con l'evento navigate
- Serializzazione e deserializzazione JSON in JavaScript
- Utilizzare app-shell per rendere un'applicazione Angular più responsiva alla partenza
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!