Informazioni di base sugli argomenti e alle sottoscrizioni del Bus di servizio di Azure (.NET)
Questo avvio rapido illustra come inviare messaggi a un argomento del Bus di servizio e ricevere messaggi da una sottoscrizione a tale argomento usando la libreria .NET Azure.Messaging.ServiceBus.
In questo avvio rapido si eseguiranno le operazioni seguenti:
- Creare uno spazio dei nomi del bus di servizio usando il portale di Azure.
- Creare un argomento del bus di servizio usando il portale di Azure.
- Creare una sottoscrizione a tale argomento del bus di servizio usando il portale di Azure.
- Scrivere un'applicazione console .NET per inviare un set di messaggi all'argomento.
- Scrivere un'applicazione console .NET per ricevere tali messaggi dalla sottoscrizione.
Nota
Questo avvio rapido fornisce istruzioni dettagliate per implementare uno scenario semplice di invio di un batch di messaggi a un argomento di Bus di servizio e ricezione di tali messaggi da una sottoscrizione dell'argomento. Per altri esempi su altri scenari e avanzati, vedere Esempi di .NET di Bus di servizio in GitHub.
- Questo avvio rapido illustra due modi per connettersi al Bus di servizio di Azure: stringa di connessione e senza password. La prima opzione mostra come usare una stringa di connessione per connettersi a uno spazio dei nomi del Bus di servizio. La seconda opzione mostra come usare l'entità di sicurezza in Microsoft Entra ID e il controllo degli accessi (RBAC) in base al ruolo per connettersi a uno spazio dei nomi del Bus di servizio. Non è necessario preoccuparsi di avere una stringa di connessione hardcoded nel codice o in un file di configurazione o in un'archiviazione sicura come Azure Key Vault. Se non si ha esperienza con Azure, è possibile trovare l'opzione stringa di connessione più semplice da seguire. È consigliabile usare l'opzione senza password in applicazioni e ambienti di produzione reali. Per altre informazioni, consultare Autenticazione e autorizzazione.
Prerequisiti
Se non si ha familiarità con il servizio, vedere Panoramica di Bus di servizio prima di seguire questo avvio rapido.
- Sottoscrizione di Azure. Per usare i servizi di Azure, tra cui Bus di servizio di Azure, è necessaria una sottoscrizione. Se non si ha un account Azure esistente, è possibile iscriversi per ottenere una versione di valutazione gratuita.
- Visual Studio 2022. L'applicazione di esempio usa nuove funzionalità introdotte in C# 10. È comunque possibile usare la libreria client di Bus di servizio con le versioni precedenti del linguaggio C#, ma la sintassi potrebbe variare. Per usare la sintassi più recente, è consigliabile installare .NET 6.0 o versione successiva e impostare la versione del linguaggio su
latest
. Se si usa Visual Studio, le versioni precedenti a Visual Studio 2022 non sono compatibili con gli strumenti necessari per la compilazione di progetti in C# 10.
Creare uno spazio dei nomi nel portale di Azure
Per iniziare a usare le entità di messaggistica del bus di servizio in Azure, prima di tutto è necessario creare uno spazio dei nomi con un nome univoco in Azure. Uno spazio dei nomi fornisce un contenitore di ambito per le risorse del Bus di servizio (code, argomenti, ecc.) all'interno dell'applicazione.
Per creare uno spazio dei nomi:
Accedere al portale di Azure.
Andare alla pagina Tutti i servizi.
Nella barra di spostamento a sinistra selezionare Integrazione nell'elenco delle categorie, passare il puntatore del mouse sul Bus di servizio quindi selezionare il pulsante + nel riquadro Bus di servizio.
Nel tag Dati principali della pagina Crea spazio dei nomi seguire questa procedura:
Per Sottoscrizione scegliere una sottoscrizione di Azure in cui creare lo spazio dei nomi.
Per Gruppo di risorse scegliere un gruppo di risorse esistente o crearne uno nuovo.
Immettere un nome per lo spazio dei nomi. Il nome dello spazio dei nomi deve rispettare le seguenti convenzioni di denominazione:
- Il nome deve essere univoco in Azure. Verrà effettuato immediatamente un controllo sulla disponibilità del nome.
- La lunghezza del nome deve essere compresa tra 6 e 50 caratteri.
- Il nome può contenere solo lettere, numeri, trattini
-
. - Il nome deve iniziare con una lettera e terminare con una lettera o un numero.
- Il nome non termina con
-sb
o-mgmt
.
Per Localitàscegliere l'area in cui deve essere ospitato lo spazio dei nomi.
In Piano tariffario, selezionare il piano tariffario (Basic, Standard o Premium) per lo spazio dei nomi. Per questo avvio rapido selezionare Standard.
Se si seleziona Il livello Premium , selezionare se è possibile abilitare la replica geografica per lo spazio dei nomi. La funzionalità di replica geografica garantisce che i metadati e i dati di uno spazio dei nomi vengano replicati continuamente da un'area primaria a una o più aree secondarie.
Importante
Se si vogliono usare argomenti e sottoscrizioni, scegliere Standard o Premium. Argomenti e sottoscrizioni non sono supportati nel piano tariffario Basic.
Se è stato selezionato il piano tariffario Premium, specificare il numero di unità di messaggistica. Il piano Premium fornisce l'isolamento delle risorse a livello di CPU e memoria in modo che ogni carico di lavoro venga eseguito in isolamento. Questo contenitore di risorse viene chiamato unità di messaggistica. Uno spazio dei nomi Premium ha almeno un'unità di messaggistica. È possibile acquistare 1, 2, 4, 8 o 16 unità di messaggistica per ogni spazio dei nomi Premium del Bus di servizio. Per altre informazioni, vedere Messaggistica Premium del bus di servizio.
Selezionare Rivedi e crea nella parte inferiore della pagina.
Nella pagina Rivedi + crea controllare le impostazioni e selezionare Crea.
Al termine della distribuzione della risorsa, selezionare Vai alla risorsa nella pagina di distribuzione.
Viene visualizzata la home page dello spazio dei nomi del bus di servizio.
Creare un argomento usando il portale di Azure
Nella pagina spazio dei nomi bus di servizio espandere Entità nel menu di spostamento a sinistra e selezionare Argomenti nel menu a sinistra.
Selezionare + Argomento sulla barra degli strumenti.
Immettere un nome per l'argomento. Lasciare invariati i valori predefiniti delle altre opzioni.
Seleziona Crea.
Creare una sottoscrizione all'argomento
Selezionare l'argomento creato nella sezione precedente.
Nella pagina Argomento di Bus di servizio selezionare + Sottoscrizione nella barra degli strumenti.
Nella pagina Crea sottoscrizione procedere come segue:
Immettere S1 per il nome della sottoscrizione.
Immettere 3 per Numero massimo di recapito.
Successivamente, selezionare Crea per creare la sottoscrizione.
Autenticare l'app in Azure
Questo avvio rapido illustra due modi per connettersi al Bus di servizio di Azure: senza password e stringa di connessione.
La prima opzione mostra come usare l'entità di sicurezza in Microsoft Entra ID e il controllo degli accessi in base al ruolo (RBAC) per connettersi a uno spazio dei nomi del Bus di servizio. Non è necessario preoccuparsi di avere una stringa di connessione hardcoded nel codice, in un file di configurazione o in un'archiviazione sicura come Azure Key Vault.
La seconda opzione mostra come usare una stringa di connessione per connettersi a uno spazio dei nomi del Bus di servizio. Se non si ha familiarità con Azure, è possibile trovare l'opzione della stringa di connessione più semplice da seguire. È consigliabile usare l'opzione senza password in applicazioni e ambienti di produzione reali. Per altre informazioni, consultare Autenticazione e autorizzazione. Per altre informazioni sull'autenticazione senza password, vedere la pagina di panoramica.
Assegnare ruoli all'utente di Microsoft Entra
Quando si sviluppa in locale, assicurarsi che l'account utente che si connette al Bus di servizio di Azure disponga delle autorizzazioni corrette. Per inviare e ricevere messaggi, è necessario il ruolo Proprietario dei dati del Bus di servizio di Azure. Per assegnare a se stessi questo ruolo, è necessario il ruolo Amministratore accesso utenti o un altro ruolo che include l'azione Microsoft.Authorization/roleAssignments/write
. È possibile assegnare ruoli controllo degli accessi in base al ruolo di Azure a un utente usando il portale di Azure, l'interfaccia della riga di comando di Azure o Azure PowerShell. Altre informazioni sugli ambiti disponibili per le assegnazioni di ruolo sono disponibili nella pagina panoramica dell'ambito .
L'esempio seguente assegna il ruolo Azure Service Bus Data Owner
all'account utente, che fornisce l'accesso completo alle risorse del Bus di servizio di Azure. In uno scenario reale, seguire il Principio dei privilegi minimi per concedere agli utenti solo le autorizzazioni minime necessarie per un ambiente di produzione più sicuro.
Ruoli predefiniti di Azure per il Bus di servizio di Azure
Per il Bus di servizio di Azure, la gestione degli spazi dei nomi e di tutte le risorse correlate tramite il portale di Azure e l'API Gestione risorse di Azure è già protetto mediante il modello RBAC di Azure. Azure fornisce i ruoli predefiniti di Azure seguenti per autorizzare l'accesso a uno spazio dei nomi del Bus di servizio:
- Proprietario dei dati del Bus di servizio di Azure: consente l'accesso dei dati allo spazio dei nomi del Bus di servizio e alle relative entità (code, argomenti, sottoscrizioni e filtri). Un membro di questo ruolo può inviare e ricevere messaggi da code o argomenti/sottoscrizioni.
- Mittente dati del bus di servizio di Azure: usare questo ruolo per concedere all'invio l'accesso allo spazio dei nomi del bus di servizio e alle relative entità.
- Destinatario dei dati del Bus di servizio di Azure: usare questo ruolo per concedere alla ricezione l'accesso allo spazio dei nomi del Bus di servizio e alle relative entità.
Per creare un ruolo personalizzato, vedere Diritti necessari per le operazioni del Bus di servizio.
Aggiungere l'utente di Microsoft Entra al ruolo Proprietario del Bus di servizio di Azure
Aggiungere il nome utente di Microsoft Entra al ruolo Proprietario dei dati del Bus di servizio di Azure a livello di spazio dei nomi del Bus di servizio. Consentirà a un'app in esecuzione nel contesto dell'account utente di inviare messaggi a una coda o a un argomento e di ricevere messaggi da una coda o da una sottoscrizione di un argomento.
Importante
Nella maggior parte dei casi, la propagazione dell'assegnazione di ruolo in Azure richiederà almeno due minuti. In rari casi, possono essere necessari fino a otto minuti. Se si ricevono errori di autenticazione quando si esegue il codice per la prima volta, attendere alcuni istanti e riprovare.
Se la pagina Spazio dei nomi del Bus di servizio non è aperta nel portale di Azure, individuare lo spazio dei nomi del Bus di servizio usando la barra di ricerca principale o lo spostamento a sinistra.
Nella pagina di panoramica selezionare Controllo di accesso (IAM) nel menu a sinistra.
Nella pagina Controllo di accesso (IAM), selezionare la scheda Assegnazioni di ruolo.
Selezionare + Aggiungi dal menu in alto e quindi Aggiungi assegnazione di ruolo dal menu a discesa risultante.
Usare la casella di ricerca per filtrare i risultati in base al ruolo desiderato. Per questo esempio, cercare
Azure Service Bus Data Owner
e selezionare il risultato corrispondente. Scegliere quindi Avanti.In Assegna accesso a selezionare Utente, gruppo o entità servizio e quindi scegliere + Seleziona membri.
Nella finestra di dialogo cercare il nome utente di Microsoft Entra (in genere l'indirizzo di posta elettronica user@domain) e quindi scegliere Selezionare nella parte inferiore della finestra di dialogo.
Selezionare Rivedi e assegna per passare alla pagina finale e quindi Rivedi e assegna di nuovo per completare il processo.
Avviare Visual Studio e accedere ad Azure
È possibile autorizzare l'accesso allo spazio dei nomi del Bus di servizio seguendo questa procedura:
Avviare Visual Studio. Se viene visualizzata la finestra Attività iniziali, selezionare il collegamento Continua senza codice nel riquadro destro.
Selezionare il pulsante Accedi in alto a destra in Visual Studio.
Accedere usando l'account Microsoft Entra a cui è stato assegnato un ruolo in precedenza.
Inviare messaggi all'argomento
Questa sezione illustra come creare un'applicazione console .NET per inviare messaggi a un argomento Bus di servizio.
Nota
Questo avvio rapido fornisce istruzioni dettagliate per implementare uno scenario semplice di invio di un batch di messaggi a un argomento di Bus di servizio e ricezione di tali messaggi da una sottoscrizione dell'argomento. Per altri esempi su altri scenari e avanzati, vedere Esempi di .NET di Bus di servizio in GitHub.
Creare un'applicazione console
- In Visual Studio selezionare il menu File ->Nuovo ->Progetto.
- Nella finestra di dialogo Crea un nuovo progetto seguire questa procedura: se non viene visualizzata questa finestra di dialogo, selezionare File dal menu, selezionare Nuovoe quindi selezionare Progetto.
Selezionare C# come linguaggio di programmazione.
Selezionare Console come tipo di applicazione.
Selezionare App console nell'elenco risultati.
Quindi seleziona Avanti.
- Immettere TopicSender come nome del progetto, ServiceBusTopicQuickStart per il nome della soluzione quindi selezionare Avanti.
- Nella pagina Informazioni aggiuntive selezionare Crea per creare la soluzione e il progetto.
Aggiungere i pacchetti NuGet al progetto
Scegliere Strumenti>Gestione pacchetti NuGet>Console di Gestione pacchetti dal menu.
Eseguire il comando seguente per installare il pacchetto NuGet Azure.Messaging.ServiceBu.
Install-Package Azure.Messaging.ServiceBus
Eseguire il comando seguente per installare il pacchetto NuGet Azure.Identity.
Install-Package Azure.Identity
Aggiungere il codice per inviare messaggi all'argomento
Sostituire il contenuto di Program.cs con il codice seguente. I passaggi importanti sono illustrati in questa sezione, con informazioni aggiuntive nei commenti del codice.
- Crea un oggetto ServiceBusClient utilizzando l'oggetto
DefaultAzureCredential
.DefaultAzureCredential
individua e usa automaticamente le credenziali dell'accesso di Visual Studio per l'autenticazione al Bus di servizio di Azure. - Richiama il metodo CreateSender nell'oggetto
ServiceBusClient
per creare un oggetto ServiceBusSender per la coda del Bus di servizio specifica. - Crea un oggetto ServiceBusMessageBatch utilizzando ServiceBusSender.CreateMessageBatchAsync.
- Aggiungere messaggi al batch usando ServiceBusMessageBatch.TryAddMessage.
- Invia il batch di messaggi all'argomento del Bus di servizio usando il metodo ServiceBusSender.SendMessagesAsync.
Importante
Aggiornare i valori segnaposto (
<NAMESPACE-NAME>
e<TOPIC-NAME>
) nel frammento di codice con i nomi dello spazio dei nomi e dell'argomento del Bus di servizio.using System.Threading.Tasks; using Azure.Messaging.ServiceBus; using Azure.Identity; // the client that owns the connection and can be used to create senders and receivers ServiceBusClient client; // the sender used to publish messages to the topic ServiceBusSender sender; // number of messages to be sent to the topic const int numOfMessages = 3; // The Service Bus client types are safe to cache and use as a singleton for the lifetime // of the application, which is best practice when messages are being published or read // regularly. //TODO: Replace the "<NAMESPACE-NAME>" and "<TOPIC-NAME>" placeholders. client = new ServiceBusClient( "<NAMESPACE-NAME>.servicebus.windows.net", new DefaultAzureCredential()); sender = client.CreateSender("<TOPIC-NAME>"); // create a batch using ServiceBusMessageBatch messageBatch = await sender.CreateMessageBatchAsync(); for (int i = 1; i <= numOfMessages; i++) { // try adding a message to the batch if (!messageBatch.TryAddMessage(new ServiceBusMessage($"Message {i}"))) { // if it is too large for the batch throw new Exception($"The message {i} is too large to fit in the batch."); } } try { // Use the producer client to send the batch of messages to the Service Bus topic await sender.SendMessagesAsync(messageBatch); Console.WriteLine($"A batch of {numOfMessages} messages has been published to the topic."); } finally { // Calling DisposeAsync on client types is required to ensure that network // resources and other unmanaged objects are properly cleaned up. await sender.DisposeAsync(); await client.DisposeAsync(); } Console.WriteLine("Press any key to end the application"); Console.ReadKey();
- Crea un oggetto ServiceBusClient utilizzando l'oggetto
Compilare il progetto e assicurarsi che non siano presenti errori.
Eseguire il programma e attendere il messaggio di conferma.
A batch of 3 messages has been published to the topic
Importante
Nella maggior parte dei casi, la propagazione dell'assegnazione di ruolo in Azure richiederà almeno due minuti. In rari casi, potrebbero essere necessari fino a otto minuti. Se si ricevono errori di autenticazione quando si esegue il codice per la prima volta, attendere alcuni istanti e riprovare.
Nel portale di Azure seguire questa procedura:
Passare allo spazio dei nomi del bus di servizio.
Nella pagina Panoramica passare alla scheda Argomenti nel riquadro centrale inferiore e selezionare l'argomento del bus di servizio. Nell'esempio seguente è
mytopic
.Nella pagina Argomento del Bus di servizio, nel grafico Messaggi della sezione Metriche in basso, sono presenti tre messaggi in ingresso per l'argomento. Se il valore non viene visualizzato, attendere alcuni minuti e aggiornare la pagina per vedere il grafico aggiornato.
Selezionare la sottoscrizione nel riquadro in basso. Nell'esempio seguente è S1. Nella pagina Sottoscrizione del Bus di servizio il valore visualizzato per Numero di messaggi attivi è 3. La sottoscrizione ha ricevuto i tre messaggi inviati all'argomento, ma non sono stati ancora prelevati da nessun destinatario.
Ricevere messaggi da una sottoscrizione
In questa sezione viene creata un'applicazione console .NET che riceve messaggi dalla sottoscrizione all'argomento del Bus di servizio.
Nota
Questo avvio rapido fornisce istruzioni dettagliate per implementare uno scenario semplice di invio di un batch di messaggi a un argomento di Bus di servizio e ricezione di tali messaggi da una sottoscrizione dell'argomento. Per altri esempi su altri scenari e avanzati, vedere Esempi di .NET di Bus di servizio in GitHub.
Creare un progetto per l'app ricevente
- Nella finestra Esplora soluzioni fare clic con il pulsante destro del mouse sulla soluzione ServiceBusTopicQuickStart, scegliere Aggiunti e selezionare Nuovo progetto.
- Selezionare Applicazione console e selezionare Avanti.
- Immettere SubscriptionReceiver per Nome progetto e selezionare Avanti.
- Nella pagina Informazioni addizionali selezionare Crea.
- Nella finestra Esplora soluzioni, fare clic con il pulsante destro del mouse su SubscriptionReceiver e scegliere Imposta come progetto di avvio.
Aggiungere i pacchetti NuGet al progetto
Scegliere Strumenti>Gestione pacchetti NuGet>Console di Gestione pacchetti dal menu.
Selezionare SubscriptionReceiver per l'elenco a discesa Progetto predefinito.
Eseguire il comando seguente per installare il pacchetto NuGet Azure.Messaging.ServiceBu.
Install-Package Azure.Messaging.ServiceBus
Eseguire il comando seguente per installare il pacchetto NuGet Azure.Identity.
Install-Package Azure.Identity
Aggiungere il codice per ricevere messaggi dalla sottoscrizione
In questa sezione si aggiunge il codice per recuperare i messaggi dalla sottoscrizione.
Sostituire il contenuto esistente di
Program.cs
con le proprietà e i metodi seguenti:using System.Threading.Tasks; using Azure.Messaging.ServiceBus; using Azure.Identity; // the client that owns the connection and can be used to create senders and receivers ServiceBusClient client; // the processor that reads and processes messages from the subscription ServiceBusProcessor processor; // handle received messages async Task MessageHandler(ProcessMessageEventArgs args) { string body = args.Message.Body.ToString(); Console.WriteLine($"Received: {body} from subscription."); // complete the message. messages is deleted from the subscription. await args.CompleteMessageAsync(args.Message); } // handle any errors when receiving messages Task ErrorHandler(ProcessErrorEventArgs args) { Console.WriteLine(args.Exception.ToString()); return Task.CompletedTask; }
Aggiungere il codice seguente alla fine di
Program.cs
.- Crea un oggetto ServiceBusClient utilizzando l'oggetto
DefaultAzureCredential
.DefaultAzureCredential
individua e usa automaticamente le credenziali dell'accesso di Visual Studio per l'autenticazione al Bus di servizio di Azure. - Richiama il metodo CreateProcessor nell'oggetto
ServiceBusClient
per creare un oggetto ServiceBusProcessor per la coda del Bus di servizio specifica. - Specifica i gestori per gli eventi ProcessMessageAsync e ProcessErrorAsync dell'oggetto
ServiceBusProcessor
. - Avvia l'elaborazione dei messaggi richiamando il StartProcessingAsync sull'oggetto
ServiceBusProcessor
. - Quando l'utente preme un tasto per terminare l'elaborazione, richiama StopProcessingAsync sull'oggetto
ServiceBusProcessor
.
Importante
Aggiornare i valori segnaposto (
<NAMESPACE-NAME>
,<TOPIC-NAME>
,<SUBSCRIPTION-NAME>
) nel frammento di codice con i nomi dello spazio dei nomi, dell'argomento e della sottoscrizione del Bus di servizio.Per ulteriori informazioni, vedere i commenti del codice.
// The Service Bus client types are safe to cache and use as a singleton for the lifetime // of the application, which is best practice when messages are being published or read // regularly. // // Create the clients that we'll use for sending and processing messages. // TODO: Replace the <NAMESPACE-NAME> placeholder client = new ServiceBusClient( "<NAMESPACE-NAME>.servicebus.windows.net", new DefaultAzureCredential()); // create a processor that we can use to process the messages // TODO: Replace the <TOPIC-NAME> and <SUBSCRIPTION-NAME> placeholders processor = client.CreateProcessor("<TOPIC-NAME>", "<SUBSCRIPTION-NAME>", new ServiceBusProcessorOptions()); try { // add handler to process messages processor.ProcessMessageAsync += MessageHandler; // add handler to process any errors processor.ProcessErrorAsync += ErrorHandler; // start processing await processor.StartProcessingAsync(); Console.WriteLine("Wait for a minute and then press any key to end the processing"); Console.ReadKey(); // stop processing Console.WriteLine("\nStopping the receiver..."); await processor.StopProcessingAsync(); Console.WriteLine("Stopped receiving messages"); } finally { // Calling DisposeAsync on client types is required to ensure that network // resources and other unmanaged objects are properly cleaned up. await processor.DisposeAsync(); await client.DisposeAsync(); }
- Crea un oggetto ServiceBusClient utilizzando l'oggetto
Di seguito è riportato come
Program.cs
dovrebbe essere:using System; using System.Threading.Tasks; using Azure.Messaging.ServiceBus; using Azure.Identity; // the client that owns the connection and can be used to create senders and receivers ServiceBusClient client; // the processor that reads and processes messages from the subscription ServiceBusProcessor processor; // handle received messages async Task MessageHandler(ProcessMessageEventArgs args) { string body = args.Message.Body.ToString(); Console.WriteLine($"Received: {body} from subscription."); // complete the message. messages is deleted from the subscription. await args.CompleteMessageAsync(args.Message); } // handle any errors when receiving messages Task ErrorHandler(ProcessErrorEventArgs args) { Console.WriteLine(args.Exception.ToString()); return Task.CompletedTask; } // The Service Bus client types are safe to cache and use as a singleton for the lifetime // of the application, which is best practice when messages are being published or read // regularly. // // Create the clients that we'll use for sending and processing messages. // TODO: Replace the <NAMESPACE-NAME> placeholder client = new ServiceBusClient( "<NAMESPACE-NAME>.servicebus.windows.net", new DefaultAzureCredential()); // create a processor that we can use to process the messages // TODO: Replace the <TOPIC-NAME> and <SUBSCRIPTION-NAME> placeholders processor = client.CreateProcessor("<TOPIC-NAME>", "<SUBSCRIPTION-NAME>", new ServiceBusProcessorOptions()); try { // add handler to process messages processor.ProcessMessageAsync += MessageHandler; // add handler to process any errors processor.ProcessErrorAsync += ErrorHandler; // start processing await processor.StartProcessingAsync(); Console.WriteLine("Wait for a minute and then press any key to end the processing"); Console.ReadKey(); // stop processing Console.WriteLine("\nStopping the receiver..."); await processor.StopProcessingAsync(); Console.WriteLine("Stopped receiving messages"); } finally { // Calling DisposeAsync on client types is required to ensure that network // resources and other unmanaged objects are properly cleaned up. await processor.DisposeAsync(); await client.DisposeAsync(); }
Compilare il progetto e assicurarsi che non siano presenti errori.
Eseguire l'applicazione ricevente. Verranno visualizzati i messaggi ricevuti. Premere un tasto qualsiasi per arrestare il destinatario e l'applicazione.
Wait for a minute and then press any key to end the processing Received: Message 1 from subscription: S1 Received: Message 2 from subscription: S1 Received: Message 3 from subscription: S1 Stopping the receiver... Stopped receiving messages
Controllare di nuovo il portale.
Nella pagina Argomento del Bus di servizio il grafico Messaggi mostra tre messaggi in ingresso e tre in uscita. Se questi valori non vengono visualizzati, attendere alcuni minuti e aggiornare la pagina per vedere il grafico aggiornato.
Nella pagina Sottoscrizione del bus di servizio il valore visualizzato per Numero di messaggi attivi è zero. Il motivo è che il destinatario ha ricevuto i messaggi inviati da questa sottoscrizione e li ha completati.
Passaggi successivi
Vedere la documentazione e gli esempi seguenti: