Esercitazione: Instradare eventi personalizzati a Connessioni ibride di Inoltro di Azure con l'interfaccia della riga di comando di Azure e Griglia di eventi

La griglia di eventi di Azure è un servizio di gestione degli eventi per il cloud. Connessioni ibride di Inoltro di Azure è uno gestore dell'evento supportato. Usare le connessioni ibride come gestore dell'evento quando è necessario elaborare gli eventi da applicazioni che non hanno un endpoint pubblico. Queste applicazioni potrebbero trovarsi all'interno della rete aziendale dell'organizzazione. Questo articolo illustra come usare l'interfaccia della riga di comando di Azure per creare un argomento personalizzato, sottoscrivere l'argomento e attivare l'evento per visualizzare il risultato. Inviare gli eventi alla connessione ibrida.

Prerequisiti

  • Questo articolo richiede l'interfaccia della riga di comando di Azure versione 2.0.56 o successiva. Se si usa Azure Cloud Shell, la versione più recente è già installata.

Creare un gruppo di risorse

Gli argomenti della griglia di eventi sono risorse di Azure e devono essere inseriti in un gruppo di risorse di Azure. Un gruppo di risorse è una raccolta logica in cui le risorse di Azure vengono distribuite e gestite.

Creare un gruppo di risorse con il comando az group create.

L'esempio seguente crea un gruppo di risorse denominato gridResourceGroup nella località westus2.

az group create --name gridResourceGroup --location westus2

Creare un argomento personalizzato

Un argomento di Griglia di eventi fornisce un endpoint definito dall'utente a cui si pubblicano gli eventi. L'esempio seguente crea l'argomento personalizzato nel gruppo di risorse. Sostituire <topic_name> con un nome univoco per l'argomento personalizzato. Il nome dell'argomento di Griglia di eventi deve essere univoco perché è rappresentato da una voce DNS.

az eventgrid topic create --name <topic_name> -l westus2 -g gridResourceGroup

Sottoscrivere un argomento personalizzato

Si sottoscrive un argomento di Griglia di eventi per indicare a Griglia di eventi gli eventi da tenere traccia. L'esempio seguente sottoscrive l'argomento personalizzato creato e passa l'ID risorsa della connessione ibrida per l'endpoint. L'ID della connessione ibrida ha il formato:

/subscriptions/<subscription-id>/resourceGroups/<resource-group-name>/providers/Microsoft.Relay/namespaces/<relay-namespace>/hybridConnections/<hybrid-connection-name>

Lo script seguente ottiene l'ID della risorsa dello spazio dei nomi di inoltro. Costruisce l'ID per la connessione ibrida e sottoscrive un argomento di Griglia di eventi. Imposta il tipo di endpoint su hybridconnection e usa l'ID della connessione ibrida per l'endpoint.

relaynsname=<namespace-name>
relayrg=<resource-group-for-relay>
hybridname=<hybrid-name>

relayid=$(az relay namespace show --resource-group $relayrg --name $relaynsname --query id --output tsv)
hybridid="$relayid/hybridConnections/$hybridname"
topicid=$(az eventgrid topic show --name <topic_name> -g gridResourceGroup --query id --output tsv)

az eventgrid event-subscription create \
  --source-resource-id $topicid \
  --name <event_subscription_name> \
  --endpoint-type hybridconnection \
  --endpoint $hybridid \
  --expiration-date "<yyyy-mm-dd>"

Si noti che per la sottoscrizione è impostata una data di scadenza.

Creare un'applicazione per elaborare gli eventi

È necessaria un'applicazione in grado di recuperare gli eventi dalla connessione ibrida. L'esempio di consumer della connessione ibrida di Griglia di eventi di Microsoft Azure per C# esegue tale operazione. I passaggi preliminari sono stati completati.

  1. Assicurarsi di disporre di Visual Studio 2019 o versioni successive.

  2. Clonare il repository nel computer locale.

  3. Caricare il progetto HybridConnectionConsumer in Visual Studio.

  4. In Program.cs, sostituire <relayConnectionString> e <hybridConnectionName> con la stringa di connessione di inoltro e il nome della connessione ibrida creata.

  5. Compilare ed eseguire l'applicazione da Visual Studio.

Inviare un evento all'argomento

Attivare un evento per vedere come la Griglia di eventi distribuisce il messaggio nell'endpoint. Questo articolo illustra come usare l'interfaccia della riga di comando di Azure per attivare l'evento. In alternativa, è possibile usare l'applicazione per la pubblicazione della Griglia di eventi.

Ottenere prima di tutto l'URL e la chiave per l'argomento personalizzato. Usare ancora una volta il nome dell'argomento personalizzato per <topic_name>.

endpoint=$(az eventgrid topic show --name <topic_name> -g gridResourceGroup --query "endpoint" --output tsv)
key=$(az eventgrid topic key list --name <topic_name> -g gridResourceGroup --query "key1" --output tsv)

Per semplificare questo articolo, si useranno dati di evento di esempio da inviare all'argomento personalizzato. In genere, i dati dell'evento vengono inviati da un'applicazione o un servizio di Azure. CURL è un'utilità che invia richieste HTTP. In questo articolo CURL viene usato per inviare l'evento all'argomento personalizzato.

event='[ {"id": "'"$RANDOM"'", "eventType": "recordInserted", "subject": "myapp/vehicles/motorcycles", "eventTime": "'`date +%Y-%m-%dT%H:%M:%S%z`'", "data":{ "make": "Ducati", "model": "Monster"},"dataVersion": "1.0"} ]'
curl -X POST -H "aeg-sas-key: $key" -d "$event" $endpoint

L'applicazione listener deve ricevere il messaggio dell'evento.

Pulire le risorse

Se si intende continuare a usare questo evento, non è necessario pulire le risorse create con questo articolo. In caso contrario, usare il comando seguente per eliminare le risorse create con questo articolo.

az group delete --name gridResourceGroup

Passaggi successivi

Ora che si è appreso come creare argomenti e sottoscrizioni di eventi, è possibile approfondire le operazioni possibili con la griglia di eventi: