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
Recuperare App Service cancellati su Azure
Persistere la ChatHistory di Semantic Kernel in ASP.NET Core Web API per GPT
Utilizzare Azure Cosmos DB con i vettori
Utilizzare Copilot con Azure Cosmos DB
Ottimizzare le pull con Artifact Cache di Azure Container Registry
Utilizzare gRPC su App Service di Azure
Bloccare l'esecuzione di un pod in mancanza di un'artifact attestation di GitHub
Path addizionali per gli asset in ASP.NET Core MVC
Combinare Container Queries e Media Queries
Gestione dell'annidamento delle regole dei layer in CSS
Utilizzare il metodo IntersectBy per eseguire l'intersection di due liste
Migliorare la scalabilità delle Azure Function con il Flex Consumption
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!