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
Utilizzare Intersect e Except per filtrare set di dati in TSql
Keynote .NET Conference Italia 2025
Disabilitare le run concorrenti di una pipeline di Azure DevOps
Anonimizzare i dati sensibili nei log di Azure Front Door
Gestire il routing HTTP in Azure Container App
Effettuare un clone parziale di un repository di GitHub
Evidenziare una porzione di testo in un pagina dopo una navigazione
Centralizzare gli endpoint AI Foundry con Azure API Management
Gestire pubblicazione Kubernetes tramite .NET Aspire
Utilizzare i variable font nel CSS
Integrare SQL Server in un progetto .NET Aspire


