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
Migliorare la scalabilità delle Azure Function con il Flex Consumption
Gestire i dati con Azure Cosmos DB Data Explorer
Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
Creare una libreria CSS universale: Nav menu
Creare una libreria CSS universale: Cards
Effettuare il refresh dei dati di una QuickGrid di Blazor
Gestire la cancellazione di una richiesta in streaming da Blazor
Utilizzare il nuovo modello GPT-4o con Azure OpenAI
Cambiare la chiave di partizionamento di Azure Cosmos DB
Configurare il nome della run di un workflow di GitHub in base al contesto di esecuzione
Creare una libreria CSS universale: Clip-path
Sfruttare al massimo i topic space di Event Grid MQTT