Transformación de datos en la aplicación de IoT Central para su exportación
Artículo
Los dispositivos IoT envían datos en varios formatos. Para usar los datos del dispositivo en la solución de IoT, es posible que tenga que transformar los datos del dispositivo antes de exportarlos a otros servicios.
En este artículo se muestra cómo transformar los datos del dispositivo como parte de una definición de exportación de datos en la aplicación IoT Central.
Las transformaciones de la definición para la exportación de datos de IoT Central permiten manipular el formato y la estructura de los datos del dispositivo antes de exportarlos a un destino. Puede especificar una transformación para cada destino en una definición de exportación. Cada mensaje pasa a través de la transformación para crear un registro de salida que se va a exportar al destino.
Use transformaciones para reestructurar cargas JSON, cambiar el nombre de los campos, filtrar campos y ejecutar cálculos sencillos en los valores de telemetría. Por ejemplo, use una transformación para convertir los mensajes en un formato tabular que coincida con el esquema de un destino, como una tabla de Azure Data Explorer.
En el vídeo siguiente se presentan las transformaciones de datos de IoT Central:
Adición de una transformación
Para agregar una transformación para un destino en la definición de exportación de datos, seleccione + Transformar, tal como se muestra en la captura de pantalla siguiente:
El panel Transformación de datos le permite especificar la transformación. En la sección 1. Agregar el mensaje de entrada, puede escribir el mensaje de ejemplo que quiere pasar a través de la transformación. También puede generar un mensaje de ejemplo seleccionando una plantilla de dispositivo. En la sección 2.Compilar una consulta de transformación, puede escribir la consulta que transforma el mensaje de entrada. La sección 3. Vista previa de los mensajes de salida muestra el resultado de la transformación:
Sugerencia
Si no conoce el formato del mensaje de entrada, use . como consulta para exportar el mensaje tal y como está a un destino, como un webhook. A continuación, pegue el mensaje que haya recibido el webhook en *1. Agregue su mensaje de entrada. Después, cree una consulta de transformación para procesar este mensaje en el formato de salida necesario.
Compilación de una consulta de transformación
El motor de transformación usa el procesador JSON de JQ de código abierto para reestructurar y dar formato a las cargas JSON. Para especificar una transformación, escriba una consulta JQ, que puede usar los filtros, funciones y características integrados de JQ. Para ver algunos ejemplos de consultas, vea Consultas de transformación de ejemplo. Para obtener más información sobre cómo escribir consultas JQ, consulte el manual de JQ.
Estructura de mensajes previa a la transformación
Puede exportar los siguientes flujos de datos de IoT Central: telemetría, cambios de propiedad, eventos de conectividad de dispositivos, eventos de ciclo de vida de dispositivos y eventos de ciclo de vida de la plantilla de dispositivo. Cada tipo de datos tiene una estructura específica que incluye información como los valores de telemetría, la información de la aplicación, los metadatos del dispositivo y los valores de propiedad.
En el ejemplo siguiente se muestra el formato de un mensaje de telemetría. Todos estos datos están disponibles para la transformación. La estructura del mensaje es similar para otros tipos de mensaje, pero hay algunos campos específicos del tipo. Puede usar la característica Agregar el mensaje de entrada para generar un mensaje de ejemplo basado en una plantilla de dispositivo en la aplicación.
Use la característica Agregar el mensaje de entrada en la interfaz de usuario de la aplicación IoT Central para ver estructuras de mensajes de ejemplo para otros tipos de exportación de datos, como los cambios de propiedad.
Consultas de transformación de ejemplo
En los ejemplos de consulta siguientes se usa el mensaje de telemetría que se muestra en la sección anterior.
Ejemplo 1: la siguiente consulta JQ genera cada parte de telemetría del mensaje de entrada como un mensaje de salida independiente:
Ejemplo 3: la siguiente consulta JQ busca el valor de telemetría RangeOfMotion y lo convierte de grados a radianes mediante la fórmula rad = degree * pi / 180. Esta consulta también muestra cómo importar y usar el módulo iotc:
Ejemplo 4: para manipular el mensaje de entrada en un formato tabular, puede asignar cada mensaje exportado en una o varias filas. La salida de fila se representa lógicamente como un objeto JSON donde el nombre de columna es la clave y el valor de la columna es el valor:
Use un formato tabular al exportar a Azure Data Explorer.
La siguiente consulta JQ escribe filas en una tabla que almacena la telemetría de rangeOfMotion en distintos dispositivos. La consulta asigna el id. de dispositivo, el tiempo de puesta en cola y el intervalo de movimiento en una tabla con estas columnas:
Un módulo JQ es una colección de funciones personalizadas. Como parte de la consulta de transformación, puede importar un módulo específico integrado de IoT Central que contenga funciones para facilitar la escritura de las consultas. Para importar el módulo de IoT Central, use la siguiente directiva:
jq
import "iotc" as iotc;
El módulo de IoT Central incluye las siguientes funciones:
find(expression): la función find le permite encontrar un elemento de matriz específico, como el valor de telemetría o la entrada de propiedad en la carga. La entrada de función es una matriz y el parámetro define un filtro JQ que se ejecuta en cada elemento de la matriz. La función devuelve cada elemento de matriz donde el filtro se evalúa como "true":
Por ejemplo, para buscar un valor de telemetría específico denominado RangeOfMotion:
jq
.telemetry | iotc::find(.name == "RangeOfMotion")
Escenarios
En los escenarios siguientes se usa la funcionalidad de transformación para personalizar el formato de datos del dispositivo para un destino específico.
Escenario 1: Exportación de datos de dispositivo a Azure Data Explorer
En este escenario, se transforman los datos del dispositivo para que coincidan con el esquema fijo de Azure Data Explorer, donde cada valor de telemetría aparece como una columna en la tabla y cada fila representa un único mensaje. Por ejemplo:
DeviceId
Marca de tiempo
T1
T2
T3
"31edabe6-e0b9-4c83-b0df-d12e95745b9f"
"2021-03-23T19:55:56.971Z
1.18898
1.434709
2.97008
Para exportar datos compatibles con esta tabla, cada mensaje exportado debe tener un aspecto parecido al del objeto siguiente. El objeto representa una sola fila, donde las claves son nombres de columna y los valores son el valor que se va a colocar en cada columna:
La consulta JQ siguiente genera los valores de telemetría T1, T2 y T3, así como Timestamp y deviceId como un mensaje con pares clave-valor que coinciden con el esquema de tabla de Azure Data Explorer:
Para obtener más información sobre cómo agregar un clúster y una base de datos de Azure Data Explorer como destino de exportación, consulte Creación de un destino de Azure Data Explorer.
Escenario 2: Separación de una matriz de telemetría
En este escenario, el dispositivo envía la siguiente matriz de telemetría en un mensaje:
Quiere transformar estos datos del dispositivo para que coincidan con el esquema de tabla siguiente:
cycleCount
deviceId
enqueuedTime
parentStatus
en ejecución
subdeviceId
2315
"9xwhr7khkfri"
"1909-10-10T07:11:56.078161042Z"
"healthy"
true
"subdevice1"
824567
"9xwhr7khkfri"
"1909-10-10T07:11:56.078161042Z"
"healthy"
false
"subdevice2"
La siguiente consulta JQ crea un mensaje de salida independiente para cada entrada de subdispositivo del mensaje e incluye información común del mensaje base y el dispositivo primario. Esta consulta simplifica la salida y separa las divisiones lógicas en los datos que llegaron como un único mensaje:
La característica de streaming en tiempo real de Power BI permite ver datos en un panel que se actualiza en tiempo real con baja latencia. Para obtener más información, consulte Streaming en tiempo real en Power BI.
Para usar IoT Central con el Streaming de Power BI, configure una exportación de webhook que envíe cuerpos de solicitud en un formato específico. En este ejemplo se supone que tiene un conjunto de datos para hacer streaming en Power BI con el esquema siguiente:
Para crear el destino de exportación de webhook, necesita el punto de conexión de la dirección URL de la API de REST para el conjunto de datos de streaming de Power BI.
En este escenario, el dispositivo envía mensajes de telemetría que son parecidos al ejemplo siguiente:
La siguiente consulta JQ transforma el mensaje de entrada en un formato adecuado para que el webhook la envíe al conjunto de datos de streaming de Power BI. En este ejemplo se incluye una condición de filtro para generar solo mensajes para una plantilla de dispositivo específica. Puede usar la característica de filtro de exportación de datos para filtrar por plantilla de dispositivo:
Escenario 4: Exportar datos a Azure Data Explorer y visualizarlos en Power BI
En este escenario, exportará datos a Azure Data Explorer y, a continuación, usará un conector para visualizarlos en Power BI. Para obtener más información sobre cómo agregar un clúster y una base de datos de Azure Data Explorer como destino de exportación, consulte Creación de un destino de Azure Data Explorer.
En este escenario se usa la tabla de Azure Data Explorer con el esquema siguiente:
La siguiente consulta JQ transforma el mensaje de entrada en un mensaje de salida independiente para cada valor de telemetría. Esta transformación genera una salida que coincide con el esquema de tabla de Azure Data Explorer. La transformación usa un esquema de tipo "entity-attribute-value" donde cada fila contiene un único valor de telemetría y el nombre de la telemetría es un valor de una columna independiente de la misma fila:
Use la aplicación Power BI Desktop para abrir el archivo IoT Central ADX Connector.pbit que descargó en el paso anterior. Cuando se le solicite, escriba la información del clúster, base de datos y tabla de Azure Data Explorer que anotó anteriormente.
Ahora ya puede visualizar los datos en Power BI:
Pasos siguientes
Ahora que sabe cómo usar la transformación de datos en IoT Central, puede realizar el siguiente paso para aprender a usar el análisis en IoT Central.
Al combinar las funcionalidades de procesamiento de flujos de Azure Stream Analytics y las funcionalidades de visualización de datos de Microsoft Power BI, puede crear paneles de datos en tiempo real.
Demostrar métodos y procedimientos recomendados que se alinean con los requisitos empresariales y técnicos para modelar, visualizar y analizar datos con Microsoft Power BI.