Quando un consumer smaltisce una Queue o una Subscription fornita da un namespace Service Bus, può ricevere messaggi che in alcune circostanze non vuole processare immediatamente (quindi rimuovere).
I motivi per cui il motore voglia aspettare il processamento possono essere molteplici: si aspetta messaggi in un certo ordine, ma non essendo garantito dalla coda questo non è successo, oppure vuole accumulare una serie di messaggi per poi combinare le informazioni tra di loro ed eseguire operazioni.
In questi casi viene in aiuto il metodo Defer della classe BrokeredMessage, il quale permette, se il lock sul messaggio è ancora valido, di tenere da parte il messaggio e di non renderlo più visibile, nonostante risieda sulla coda. E' compito poi del consumer tenere da parte il SequenceNumber, sempre diponsibile sul messaggio, per poterne poi farne richiesta con il metodo Receive.
Di seguito quindi un esempio che accumula tre messaggi, facendone il Defer, per poi andare a recuperarli.
// Creo il client della coda var client = messagingFactory.CreateQueueClient("myQueue"); List<long> numbers = new List<long>(); // Accumulo tre sequence number dei messaggi while (numbers.Count < 3) { // Ricevo il messaggio disponibile BrokeredMessage bm = client.Receive(); // Applico una condizione per decidere se farne il Defer o meno if (true) { numbers.Add(bm.SequenceNumber); bm.Defer(); } else { bm.Delete(); } } // Sfoglio tutti i sequence number messi da parte foreach (long n in numbers) { // Chiedo esplicitamente un messaggio BrokeredMessage bm = client.Receive(n); // Cancello il messaggio bm.Delete(); // Faccio qualcosa con il messaggio // ... }
Da notare come nella seconda parte del motore, al metodo Receive venga passato esplicitamente il sequence number dei messaggi di cui si è fatto il Defer.
Per ulteriori informazioni su Queue, i Topic e le Subscription si veda l'articolo
https://www.winfxitalia.com/articoli/windows-azure/sms-windows-phone-azure-queue.aspx
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Ottenere un token di accesso per una GitHub App
Gestire codice JavaScript con code splitting e lazy loading
Implementare il throttle in JavaScript
Gestire il routing HTTP in Azure Container App
Sfruttare gli embedding e la ricerca vettoriale con Azure SQL Database
Migliorare la scalabilità delle Azure Function con il Flex Consumption
Generare una User Delegation SAS in .NET per Azure Blob Storage
Fissare una versione dell'agent nelle pipeline di Azure DevOps
.NET Conference Italia 2024
Utilizzare il metodo IntersectBy per eseguire l'intersection di due liste
Migliorare l'organizzazione delle risorse con Azure Policy
Utilizzare Containers in .NET Aspire
I più letti di oggi
- Usare i settings di serializzazione/deserializzazione di System.Text.Json di ASP.NET all'interno di un'applicazione non web
- .NET Conference Italia 2025 - Milano
- The Agentic Day - Milano
- Gestione ciclo di vita in .NET Aspire
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Gestione CSS in Blazor con .NET 9
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Gestione file Javascript in Blazor con .NET 9