Exportera IoT-data till Webhook

Den här artikeln beskriver hur du konfigurerar dataexport för att skicka data till Webhook.

Använd den här funktionen för att kontinuerligt exportera filtrerade och berikade IoT-data från ditt IoT Central-program. Dataexport överför ändringar i nära realtid till andra delar av molnlösningen för insikter, analyser och lagring med varma vägar.

Du kan till exempel:

  • Exportera kontinuerligt telemetri, egenskapsändringar, enhetsanslutning, enhetens livscykel, livscykel för enhetsmallar och granskningsloggdata i JSON-format nästan i realtid.
  • Filtrera dataströmmarna för att exportera data som matchar anpassade villkor.
  • Utöka dataströmmarna med anpassade värden och egenskapsvärden från enheten.
  • Transformera dataströmmarna för att ändra form och innehåll.

Dricks

När du aktiverar dataexport får du bara data från det ögonblicket och framåt. Om du vill behålla mer historiska data aktiverar du dataexport tidigt. Information om hur du exporterar data manuellt från tidpunkter då dataexporten stängdes av finns i Så här använder du REST-API:et för IoT Central för att fråga enheter.

Kommentar

I vissa fall kan det ta upp till 60 sekunder innan meddelandena exporteras. Den här tiden mäts från när IoT Central tar emot meddelandet från den underliggande IoT-hubben till när meddelandet levereras till målslutpunkten.

Förutsättningar

Om du vill använda dataexportfunktioner måste du ha behörigheten Dataexport .

Konfigurera ett Webhook-exportmål

För Webhook-mål exporterar IoT Central data nästan i realtid. Data i meddelandetexten är i samma format som för Event Hubs och Service Bus.

Skapa ett Webhook-mål

Du kan exportera data till en offentligt tillgänglig HTTP Webhook-slutpunkt. Du kan skapa en Webhook-testslutpunkt med RequestBin. RequestBin begränsar begäran när gränsen för begäran har nåtts:

  1. Gå till RequestBin.

  2. Välj Skapa en RequestBin.

  3. Logga in med någon av de tillgängliga metoderna.

  4. Kopiera URL:en för din RequestBin Du använder den här URL:en när du testar dataexporten.

Så här skapar du Azure Data Explorer-målet i IoT Central på sidan Dataexport :

  1. Välj + Nytt mål.

  2. Välj Webhook som måltyp.

  3. Klistra in motringnings-URL:en för Webhook-slutpunkten. Du kan också konfigurera Webhook-auktorisering och lägga till anpassade rubriker.

    • För OAuth2.0 stöds endast flödet för beviljande av klientautentiseringsuppgifter. När du sparar målet kommunicerar IoT Central med din OAuth-provider för att hämta en auktoriseringstoken. Den här token är kopplad till Authorization huvudet för varje meddelande som skickas till det här målet.
    • För auktoriseringstoken kan du ange ett tokenvärde som är direkt kopplat till Authorization rubriken för varje meddelande som skickas till det här målet.
  4. Välj Spara.

Exempel på OAuth 2.0-konfiguration

Det här exemplet visar hur du konfigurerar ett Webhook-mål för att använda en Azure-funktionsapp som skyddas med hjälp av Microsoft Entra-inloggning:

Inställning Exempel Kommentar
Måltyp Webhook
Återanrops-URL https://myapp.azurewebsites.net/api/HttpExample Funktions-URL:en.
Auktorisering OAuth 2.0
Token-URL https://login.microsoftonline.com/your-tenant-id/oauth2/v2.0/token Url:en som ska användas för att hämta en token. Du hittar det här värdet i funktionsappen: Autentisering > Din Microsoft Identity Provider > Endpoints > OAuth 2.0-tokenslutpunkt (v2)
Client ID your-client-id Klient-ID för funktionsappen. Du hittar det här värdet i funktionsappen: Autentisering > Ditt Microsoft Identity Provider > Application (klient)-ID
Klienthemlighet your-client-secret Klienthemligheten för funktionsappen. Du hittar det här värdet i funktionsappen: Autentisering > Dina Certifikat och hemligheter för Microsoft-identitetsprovidern >
Målgrupp Ej tillämpligt Tom om du använder en funktionsapp.
Omfattning https://your-client-id/.default Tokens omfång. För en funktionsapp använder du klient-ID-värdet.**
Innehållstyp för tokenbegäran Auto

Andra webhooksdestinationer kan kräva olika värden för de här inställningarna.

Konfigurera en dataexport

Nu när du har ett mål att exportera dina data till konfigurerar du dataexport i ditt IoT Central-program:

  1. Logga in på ditt IoT Central-program.

  2. I den vänstra rutan väljer du Dataexport.

    Dricks

    Om du inte ser dataexport i den vänstra rutan har du inte behörighet att konfigurera dataexport i din app. Prata med en administratör för att konfigurera dataexport.

  3. Välj + Ny export.

  4. Ange ett visningsnamn för den nya exporten och kontrollera att dataexporten är Aktiverad.

  5. Välj vilken typ av data som ska exporteras. I följande tabell visas de dataexporttyper som stöds:

    Datatyp beskrivning Dataformat
    Telemetri Exportera telemetrimeddelanden från enheter nästan i realtid. Varje exporterat meddelande innehåller det fullständiga innehållet i det ursprungliga enhetsmeddelandet, normaliserat. Meddelandeformat för telemetri
    Egenskapsändringar Exportera ändringar av enhets- och molnegenskaper nästan i realtid. För skrivskyddade enhetsegenskaper exporteras ändringar av de rapporterade värdena. För skrivskyddade egenskaper exporteras både rapporterade och önskade värden. Meddelandeformat för egenskapsändring
    Enhetsanslutning Exportera enhetsanslutna och frånkopplade händelser. Meddelandeformat för enhetsanslutning
    Enhetens livscykel Exportera registrerade, borttagna, etablerade, aktiverade, inaktiverade, displayNameChanged- och deviceTemplateChanged-händelser. Enhetens livscykel ändrar meddelandeformat
    Livscykel för enhetsmall Exportera publicerade enhetsmalländringar, inklusive skapade, uppdaterade och borttagna. Meddelandeformat för ändring av meddelandeformat för enhetsmallens livscykel
    Granskningsloggar Loggar över användarinitierade uppdateringar av entiteter i programmet. Mer information finns i Använda granskningsloggar för att spåra aktivitet i ditt IoT Central-program Format för granskningsloggmeddelande
  6. Du kan också lägga till filter för att minska mängden data som exporteras. Det finns olika typer av filter för varje dataexporttyp:

    Typ av data Tillgängliga filter
    Telemetri
    • Filtrera efter enhetsnamn, enhets-ID, enhetsmall och om enheten simuleras
    • Filterströmmen får endast innehålla telemetri som uppfyller filtervillkoren
    • Filtrera dataström så att den endast innehåller telemetri från enheter med egenskaper som matchar filtervillkoren
    • Filtrera dataström så att den endast innehåller telemetri som har meddelandeegenskaper som uppfyller filtervillkoret. Meddelandeegenskaper (även kallade programegenskaper) skickas i en påse nyckel/värde-par på varje telemetrimeddelande. Om du vill skapa ett filter för meddelandeegenskap anger du den meddelandeegenskapsnyckel som du letar efter och anger ett villkor. Endast telemetrimeddelanden med egenskaper som matchar det angivna filtervillkoret exporteras. Läs mer om programegenskaper från IoT Hub-dokument
    Egenskapsändringar
    • Filtrera efter enhetsnamn, enhets-ID, enhetsmall och om enheten simuleras
    • Filterström för att endast innehålla egenskapsändringar som uppfyller filtervillkoren
    Enhetsanslutning
    • Filtrera efter enhetsnamn, enhets-ID, enhetsmall, organisationer och om enheten simuleras
    • Filtrera dataström så att den endast innehåller ändringar från enheter med egenskaper som matchar filtervillkoren
    Enhetens livscykel
    • Filtrera efter enhetsnamn, enhets-ID, enhetsmall och om enheten har etablerats, aktiverats eller simulerats
    • Filtrera dataström så att den endast innehåller ändringar från enheter med egenskaper som matchar filtervillkoren
    Livscykel för enhetsmall
    • Filtrera efter enhetsmall
    Granskningsloggar Ej tillämpligt
  7. Du kan också utöka exporterade meddelanden med extra nyckel/värde-parmetadata. Följande berikanden är tillgängliga för dataexporttyperna telemetri, egenskapsändringar, enhetsanslutning och enhetslivscykel:

    • Anpassad sträng: Lägger till en anpassad statisk sträng i varje meddelande. Ange valfri nyckel och ange valfritt strängvärde.
    • Egenskap som lägger till i varje meddelande:
      • Enhetsmetadata som enhetsnamn, enhetsmallnamn, aktiverat, organisationer, etablerade och simulerade.
      • Den aktuella enheten rapporterade egenskaps- eller molnegenskapsvärdet för varje meddelande. Om det exporterade meddelandet kommer från en enhet som inte har den angivna egenskapen får det exporterade meddelandet inte berikningen.

Konfigurera exportmålet:

  1. Välj + Mål för att lägga till ett mål som du redan har skapat eller välj Skapa ett nytt.

  2. Om du vill transformera dina data innan de exporteras väljer du + Transformera. Mer information finns i Transformera data i ditt IoT Central-program för export.

  3. Välj + Mål för att lägga till upp till fem mål för en enskild export.

  4. När du har konfigurerat exporten väljer du Spara. Efter några minuter visas dina data i dina mål.

Övervaka exporten

På sidan Dataexport i IoT Central kan du kontrollera statusen för dina exporter. Du kan också använda Azure Monitor för att se hur mycket data du exporterar och eventuella exportfel. Du kan komma åt export- och enhetshälsomått i diagram i Azure-portalen med hjälp av REST-API:et, frågor i PowerShell eller Azure CLI. För närvarande kan du övervaka följande dataexportmått i Azure Monitor:

  • Antal meddelanden som ska exporteras innan filter tillämpas.
  • Antal meddelanden som passerar genom filter.
  • Antal meddelanden som har exporterats till mål.
  • Antal fel som hittades.

Mer information finns i Övervaka programmets hälsa.

Dataformat

I följande avsnitt beskrivs formaten för exporterade data:

Telemetriformat

Varje exporterat meddelande innehåller en normaliserad form av det fullständiga meddelandet som enheten skickade i meddelandetexten. Meddelandet är i JSON-format och kodat som UTF-8. Information i varje meddelande innehåller:

  • applicationId: ID för IoT Central-programmet.
  • messageSource: Källan för meddelandet – telemetry.
  • deviceId: ID för enheten som skickade telemetrimeddelandet.
  • schema: Namnet och versionen av nyttolastschemat.
  • templateId: ID för enhetsmallen som tilldelats enheten.
  • enqueuedTime: Den tidpunkt då IoT Central tog emot det här meddelandet.
  • enrichments: Alla berikningar som har konfigurerats vid exporten.
  • module: IoT Edge-modulen som skickade det här meddelandet. Det här fältet visas bara om meddelandet kom från en IoT Edge-modul.
  • component: Komponenten som skickade det här meddelandet. Det här fältet visas bara om funktionerna som skickades i meddelandet modellerades som en komponent i enhetsmallen
  • messageProperties: Andra egenskaper som enheten skickade med meddelandet. Dessa egenskaper kallas ibland för programegenskaper. Läs mer i IoT Hub-dokument.

Meddelandeegenskaper

Telemetrimeddelanden har egenskaper för metadata och telemetrinyttolasten. Föregående kodfragment visar exempel på systemmeddelanden som deviceId och enqueuedTime. Mer information om systemmeddelandeegenskaperna finns i Systemegenskaper för D2C IoT Hub-meddelanden.

Du kan lägga till egenskaper i telemetrimeddelanden om du behöver lägga till anpassade metadata i dina telemetrimeddelanden. Du måste till exempel lägga till en tidsstämpel när enheten skapar meddelandet.

Följande kodfragment visar hur du lägger iothub-creation-time-utc till egenskapen i meddelandet när du skapar den på enheten:

Viktigt!

Formatet för den här tidsstämpeln måste vara UTC utan tidszonsinformation. Är till exempel 2021-04-21T11:30:16Z giltigt, 2021-04-21T11:30:16-07:00 är ogiltigt.

async function sendTelemetry(deviceClient, index) {
  console.log('Sending telemetry message %d...', index);
  const msg = new Message(
    JSON.stringify(
      deviceTemperatureSensor.updateSensor().getCurrentTemperatureObject()
    )
  );
  msg.properties.add("iothub-creation-time-utc", new Date().toISOString());
  msg.contentType = 'application/json';
  msg.contentEncoding = 'utf-8';
  await deviceClient.sendEvent(msg);
}

Format för egenskapsändringar

Varje meddelande eller post representerar ändringar i enhets- och molnegenskaper. Informationen i det exporterade meddelandet innehåller:

  • applicationId: ID för IoT Central-programmet.
  • messageSource: Källan för meddelandet – properties.
  • messageType: Antingen cloudPropertyChange, devicePropertyDesiredChangeeller devicePropertyReportedChange.
  • deviceId: ID för enheten som skickade telemetrimeddelandet.
  • schema: Namnet och versionen av nyttolastschemat.
  • enqueuedTime: Den tidpunkt då IoT Central identifierade den här ändringen.
  • templateId: ID för enhetsmallen som tilldelats enheten.
  • properties: En matris med egenskaper som har ändrats, inklusive namnen på de egenskaper och värden som har ändrats. Komponent- och modulinformationen ingår om egenskapen modelleras inom en komponent eller en IoT Edge-modul.
  • enrichments: Alla berikningar som har konfigurerats vid exporten.

Format för enhetsanslutningsändringar

Varje meddelande eller post representerar en anslutningshändelse från en enda enhet. Informationen i det exporterade meddelandet innehåller:

  • applicationId: ID för IoT Central-programmet.
  • messageSource: Källan för meddelandet – deviceConnectivity.
  • messageType: Antingen connected eller disconnected.
  • deviceId: ID:t för enheten som ändrades.
  • schema: Namnet och versionen av nyttolastschemat.
  • templateId: ID för enhetsmallen som tilldelats enheten.
  • enqueuedTime: Den tidpunkt då den här ändringen inträffade i IoT Central.
  • enrichments: Alla berikningar som har konfigurerats vid exporten.

Ändra format för enhetens livscykel

Varje meddelande eller post representerar en ändring av en enskild enhet. Informationen i det exporterade meddelandet innehåller:

  • applicationId: ID för IoT Central-programmet.
  • messageSource: Källan för meddelandet – deviceLifecycle.
  • messageType: Den typ av ändring som inträffade. En av: registered, deleted, provisioned, enabled, disabled, displayNameChangedoch deviceTemplateChanged.
  • deviceId: ID:t för enheten som ändrades.
  • schema: Namnet och versionen av nyttolastschemat.
  • templateId: ID för enhetsmallen som tilldelats enheten.
  • enqueuedTime: Den tidpunkt då den här ändringen inträffade i IoT Central.
  • enrichments: Alla berikningar som har konfigurerats vid exporten.

Ändringsformat för enhetsmallens livscykel

Varje meddelande eller post representerar en ändring i en enda publicerad enhetsmall. Informationen i det exporterade meddelandet innehåller:

  • applicationId: ID för IoT Central-programmet.
  • messageSource: Källan för meddelandet – deviceTemplateLifecycle.
  • messageType: Antingen created, updatedeller deleted.
  • schema: Namnet och versionen av nyttolastschemat.
  • templateId: ID för enhetsmallen som tilldelats enheten.
  • enqueuedTime: Den tidpunkt då den här ändringen inträffade i IoT Central.
  • enrichments: Alla berikningar som har konfigurerats vid exporten.

Format för granskningsloggar

Varje granskningsloggmeddelande representerar en användarinitierad ändring av en granskningsbar entitet i IoT Central-programmet. Informationen i det exporterade meddelandet innehåller:

  • actor: Information om användaren som ändrade entiteten.
  • applicationId: ID för IoT Central-programmet.
  • messageSource: Källan för meddelandet – audit.
  • messageType: Den typ av ändring som inträffade. En av: updated, created, deleted.
  • updated: Presentera endast om messageType är updated. Innehåller mer information om uppdateringen.
  • resource: Information om den ändrade entiteten.
  • schema: Namnet och versionen av nyttolastschemat.
  • deviceId: ID:t för enheten som ändrades.
  • enqueuedTime: Den tidpunkt då den här ändringen inträffade i IoT Central.
  • enrichments: Alla berikningar som har konfigurerats vid exporten.

Nästa steg

Nu när du vet hur du exporterar till Service Bus är ett föreslaget nästa steg att lära dig Exportera till Händelsehubbar.