La transmisión de datos es el flujo continuo de datos en tiempo real desde varias fuentes. A diferencia del procesamiento por lotes, que maneja conjuntos de datos a intervalos programados, los datos de transmisión se procesan a medida que llegan para obtener insights inmediatos y en tiempo real.
Hoy en día, las organizaciones generan grandes volúmenes de datos sobre todo tipo de aspectos, desde dispositivos del Internet de las cosas (IoT) hasta transacciones de comercio electrónico. La transmisión de datos, también conocida como “streaming de datos” o “transmisión de datos en tiempo real”, ayuda a las organizaciones a procesar estos flujos de datos continuos a medida que entran.
Algunos ejemplos de transmisión de datos incluyen:
Las organizaciones suelen utilizar la transmisión de datos para respaldar iniciativas empresariales que dependen de datos en tiempo real para una toma de decisiones rápida basada en datos, como el análisis de datos y la business intelligence (BI).
La transmisión de datos suele formar parte de los esfuerzos de recopilación y procesamiento de big data. Por ejemplo, las organizaciones pueden analizar flujos de datos continuos mediante el uso de analytics de big data para obtener insight sobre la eficiencia operativa, las tendencias de los consumidores y la dinámica cambiante del mercado.
Debido a que fluye continuamente, la transmisión de datos requiere métodos de procesamiento diferentes a los del procesamiento por lotes tradicional. Estos a menudo incluyen arquitecturas de transmisión escalables y procesadores de flujo que gestionan la ingesta, el procesamiento y el análisis de datos mientras mantienen un rendimiento óptimo.
En los últimos años, el auge de la inteligencia artificial (IA) y el machine learning ha hecho que se preste aún más atención a las capacidades de transmisión de datos. Estas tecnologías suelen basarse en el procesamiento de datos en tiempo real para generar insights y predicciones en tiempo real.
Según Gartner, el 61 % de las organizaciones informan que tienen que evolucionar o repensar su modelo operativo de datos y analytics debido al impacto de las tecnologías de AI.1
WealthAPI, una fintech, construyó su plataforma de analytics financiero alrededor de una arquitectura de transmisión orientada a eventos para gestionar flujos continuos de datos bancarios y de transacciones incongruentes en tiempo real. Los datos entrantes se almacenan en un búfer y se distribuyen a través de Google Publish/Subscribe, un servicio de mensajería que separa a los productores de datos de los sistemas posteriores y permite que varios servicios consuman el mismo flujo de forma simultánea. IBM watsonx.data se encarga entonces de la recuperación de datos estructurados de alto rendimiento, ofreciendo insights financieros hasta un 80 % más rápida, sirviendo a decenas de miles de usuarios mientras escala a millones sin cambios arquitectónicos.
Manténgase al día sobre las tendencias más importantes e intrigantes de la industria sobre IA, automatización, datos y más con el boletín Think. Consulte la Declaración de privacidad de IBM.
Las organizaciones pueden procesar datos de dos maneras principales: procesamiento por lotes o transmisión de datos.
Si bien ambos métodos manejan grandes volúmenes de datos, sirven para diferentes casos de uso y requieren diferentes arquitecturas.
Las diferencias clave incluyen:
Las organizaciones suelen elegir entre el procesamiento por lotes y por flujos en función de los volúmenes de datos, las necesidades de latencia y los objetivos empresariales. Muchas emplean ambos enfoques dentro de un tejido de datos unificado para gestionar distintos tipos de tareas de datos.
Por ejemplo, una organización de comercio electrónico podría usar el procesamiento por lotes para generar informes de ventas diarios mientras usa datos de transmisión y sistemas de análisis en tiempo real para monitorear métricas clave del sitio web.
A un alto nivel, la transmisión de datos funciona capturando, procesando y analizando continuamente flujos de datos en tiempo real de diversas fuentes. Este proceso consta de cuatro etapas clave:
La primera etapa consiste en capturar flujos de datos entrantes de diversas fuentes. Las herramientas modernas de ingesta de datos, como el búfer Apache Kafka, estandarizan estos flujos a medida que llegan, lo que ayuda a garantizar tanto la escalabilidad como la coherencia de los datos.
Las organizaciones suelen realizar la Integración de herramientas de ingesta de datos con otros componentes para crear flujos de trabajo unificados. Las herramientas de integración de datos también pueden alinear aún más los tipos de datos dispares en un formato estandarizado para el procesamiento para ayudar a garantizar que los datos de múltiples fuentes se puedan combinar y analizar de manera efectiva.
En la etapa de procesamiento, las infraestructuras de procesamiento de transmisión como Apache Flink analizan y transforman los datos mientras están en movimiento. Estas infraestructuras permiten a las organizaciones:
En esta etapa, las organizaciones obtienen insights empresariales procesables a partir de la transmisión de flujos de datos a través de la visualización de datos y otras herramientas analíticas.
Las aplicaciones clave incluyen:
Al almacenar datos de transmisión, las organizaciones deben equilibrar la necesidad de acceder rápidamente a los datos para su uso en tiempo real con el almacenamiento de datos, la rentabilidad y las preocupaciones de cumplimiento de datos a largo plazo.
Muchas organizaciones emplean data lakes y lakehouses de datos para almacenar datos en streaming porque estas soluciones ofrecen entornos de almacenamiento flexibles y de bajo costo para grandes cantidades de datos. Después de capturar los datos de transmisión, es posible que se envíen a un almacén de datos, donde se pueden limpiar y preparar para su uso.
Las organizaciones suelen implementar múltiples soluciones de almacenamiento de datos juntas en un tejido de datos unificado. Por ejemplo, las instituciones financieras pueden usar data lakes para almacenar flujos de transacciones sin procesar mientras usan almacenes para analytics e informes.
Las organizaciones pueden utilizar muchos tipos de datos de transmisión para respaldar el análisis en tiempo real y la toma de decisiones. Algunos de los flujos de datos de transmisión más comunes incluyen:
Los flujos de eventos capturan las acciones o cambios del sistema a medida que se producen, como las llamadas a la interfaz de programación de aplicaciones (API), clics en el sitio web o entradas de registro de la aplicación. Los flujos de eventos se utilizan comúnmente para realizar un seguimiento de las actividades en tiempo real en todos los sistemas, lo que permite respuestas instantáneas a las interacciones de los usuarios o a los eventos del sistema.
Los datos de transacciones en tiempo real capturan flujos continuos de transacciones comerciales, como pagos digitales o compras de comercio electrónico. Los datos de transacciones en tiempo real respaldan aplicaciones como la detección de fraudes y la toma de decisiones instantánea.
Los datos de IoT y sensores incluyen información sobre las condiciones ambientales, el rendimiento del equipamiento y los procesos físicos. Estos flujos de datos a menudo admiten el monitoreo de equipamiento en tiempo real y la automatización de procesos.
La transmisión de datos permite a las organizaciones procesar grandes volúmenes de información en tiempo real para obtener insights y acciones inmediatas.
Las aplicaciones comunes son:
Las instituciones financieras utilizan con frecuencia analytics de streaming para procesar datos de mercado, transacciones e interacciones con los clientes.
Por ejemplo, las empresas de tarjetas de crédito confían en la transmisión de datos para la detección de fraudes. Las plataformas de transmisión de datos permiten a estas empresas analizar miles de transacciones por segundo para detectar actividades inusuales y marcar o bloquear transacciones sospechosas.
Las instalaciones modernas de fabricación a menudo utilizan sensores de dispositivos IoT y procesamiento de datos en tiempo real para mejorar la eficiencia operativa.
Por ejemplo, una planta automotriz podría monitorear miles de sensores de línea de ensamblaje, rastreando métricas como temperatura, vibración y rendimiento. Estos datos pueden ayudar a los operadores a detectar ineficiencias de manera temprana y programar el mantenimiento preventivo para evitar el tiempo de inactividad.
Los proveedores de atención médica confían en las aplicaciones de transmisión para procesar datos de dispositivos médicos y sistemas de monitoreo de pacientes.
En las unidades de cuidados intensivos, por ejemplo, los monitores de cabecera transmiten los signos vitales a través de canales de datos a procesadores centrales, que pueden identificar patrones preocupantes y alertar automáticamente al personal médico cuando es necesaria una intervención.
Los minoristas y las empresas de comercio electrónico utilizan datos de transmisión de los sistemas de punto de venta, sensores de inventario y plataformas en línea para optimizar las operaciones.
Por ejemplo, una gran plataforma de comercio electrónico puede usar Apache Kafka para procesar flujos de clics de millones de compradores para medir la demanda y personalizar las experiencias del cliente.
Las empresas de transporte a menudo utilizan streaming analytics para procesar datos GPS y lecturas de sensores IoT para optimizar la flota.
Por ejemplo, un proveedor de logística puede integrar datos en tiempo real de miles de vehículos con conjuntos de datos meteorológicos y de tráfico. Los procesadores de flujo pueden habilitar la optimización automatizada de rutas con una latencia mínima para ayudar a los conductores a evitar retrasos.
La transmisión de datos ayuda a respaldar medidas de ciberseguridad como la detección automatizada de anomalías. Los sistemas de IA y machine learning pueden analizar los flujos de datos de las herramientas de monitoreo en todo el sistema para identificar patrones inusuales o comportamientos sospechosos, lo que permite respuestas inmediatas a posibles problemas.
La transmisión de datos también juega un papel vital en la IA y el machine learning. Por ejemplo, los marcos de procesamiento de flujos pueden admitir el entrenamiento continuo de modelos de IA para que los algoritmos de machine learning puedan adaptarse a los patrones cambiantes en tiempo casi real.
Los sistemas de machine learning también pueden aprender de manera incremental a partir de fuentes de datos en transmisión a través de un proceso llamado aprendizaje en línea, utilizando algoritmos especializados para mejorar la precisión sin requerir un reentrenamiento completo del modelo.
Con la ayuda de soluciones de transmisión de datos comerciales y de código abierto, las organizaciones pueden crear pipelines de datos escalables que sean tolerantes a fallas, lo que significa que pueden recuperarse de fallas sin pérdida de datos ni tiempo de inactividad.
Dos tipos clave de tecnologías sustentan la mayoría de las implementaciones de datos de streaming: las infraestructuras de procesamiento de transmisión y las plataformas de datos de transmisión.
Los marcos de procesamiento de flujos proporcionan la base para gestionar flujos de datos continuos. Estos marcos ayudan a las organizaciones a crear pipelines de alto rendimiento que procesan grandes volúmenes de datos de forma coherente, rápida y fiable.
Tres marcos de código abierto dominan el panorama del streaming:
Kafka, una plataforma líder de transmisión, puede manejar volúmenes masivos de datos con latencia de milisegundos. Las organizaciones suelen utilizar Kafka para crear pipelines para el seguimiento de actividades, la supervisión operativa y la agregación de registros.
Apache Flink se especializa en el procesamiento de eventos complejos y cálculos con estado. Es valioso para el análisis en tiempo real, la detección de fraude y el mantenimiento predictivo, donde es crítico comprender el contexto de los eventos a lo largo del tiempo.
Conocido por sus capacidades de analytics unificadas, Spark puede manejar datos por lotes y de transmisión simultáneamente. Esta capacidad lo hace útil en escenarios en los que las organizaciones necesitan analizar datos históricos junto con datos en vivo.
Las plataformas de transmisión de datos ofrecen diversas herramientas y funciones para ayudar a soportar todo el ciclo de vida de los datos de streaming, desde la ingestión y el procesamiento hasta el almacenamiento de información y la integración.
Muchos de los principales proveedores de la nube ofrecen soluciones de transmisión de datos gestionadas que facilitan a las organizaciones la configuración de aplicaciones de transmisión de datos de gran volumen. Servicios como Amazon Kinesis de Amazon Web Services (AWS), Microsoft Azure Stream analytics, Dataflow de Google Cloud e IBM Event Streams proporcionan herramientas listas para usar. Las empresas no tienen que crear infraestructuras complejas desde cero.
Estos servicios también pueden integrarse con herramientas de transmisión on-premises para crear arquitecturas híbridas que pueden ayudar a equilibrar las necesidades de rendimiento con los requisitos de privacidad de datos.
Las organizaciones también pueden utilizar herramientas como IBM StreamSets y Confluent para crear canales de transmisión de datos adaptados a sus ecosistemas de TI únicos.
Si bien la transmisión de datos puede ofrecer muchos beneficios, las organizaciones pueden enfrentar desafíos al crear las arquitecturas de datos necesarias para admitir aplicaciones de transmisión.
Algunos desafíos comunes incluyen:
Organice sus datos con las soluciones de plataforma IBM DataOps para garantizar su fiabilidad y prepararlos para la IA a nivel empresarial.
Cree y gestione canalizaciones de datos de streaming inteligentes a través de una interfaz gráfica intuitiva, y facilite una integración de datos fluida en entornos híbridos y multinube.
Desbloquee el valor de los datos empresariales con IBM Consulting y cree una organización impulsada por insights que ofrezca ventajas empresariales.
1 "Gartner Survey Finds 61% of Organizations Are Evolving Their D&A Operating Model Because of AI Technologies," Gartner. 29 de abril de 2024.