Nell'articolo introduttivo su Queue, i Topic e le Subscription del Service Bus di Windows Azure si è menzionato al fatto che tra le varie funzionalità che si ha disposizione vi è la dead letter. Questa si tratta, di fatto, di un'ulteriore coda dove è possibile depositare messaggi ricevuti dalla coda principale, che per qualche motivo si decide di mettere in disparte per un ulteriore processamento, come segnalazione di una mancata elaborazione o per depositare messaggi scaduti.
Per sfruttare quest'ultima caratteristica è necessario indicarne il supporto in fase di creazione della coda sfruttando la QueueDescription.
QueueDescription qd = new QueueDescription("test"); qd.EnableDeadLetteringOnMessageExpiration = true; namespaceManager.CreateQueue(qd);
In questo modo ogni messaggio che non verrà ricevuto entro la data di scadenza, verrà spostato automaticamente nella dead letter. E' possibile inoltre indicare in modo esplicito di riporre un messaggio ricevuto all'interno della dead letter chiamando il metodo DeadLetter e indicando facoltativamente una descrizione.
BrokeredMessage receivedMessage; // ricevo il messaggio... receivedMessage.DeadLetter("UnableToProcess", "Failed to process in reasonable attempts");
A questo punto il client stesso o un altro motore può ricevere i messaggi della dead letter creado un client apposito.
var client = messagingFactory.CreateQueueClient(QueueClient.FormatDeadLetterPath("test")); client.Receive();
Come si può vedere dal codice, il nome della coda viene ottenuto con un metodo apposito che ne formatta il nome aggiungendo il suffisso "/$DeadLetterQueue".
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
Supportare la sessione affinity di Azure App Service con Application Gateway
Sfruttare GPT-4o realtime su Azure Open AI per conversazioni vocali
Configurare il nome della run di un workflow di GitHub in base al contesto di esecuzione
Popolare una classe a partire dal testo, con Semantic Kernel e ASP.NET Core Web API
Utilizzare l'espressione if inline in una pipeline di Azure DevOps
Utilizzare Container Queries nominali
Triggerare una pipeline su un altro repository di Azure DevOps
Utilizzare Locust con Azure Load Testing
Proteggere le risorse Azure con private link e private endpoints
Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
Gestione file Javascript in Blazor con .NET 9
Applicare un filtro per recuperare alcune issue di GitHub
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!