Arquitectura del conjunto de datos en un Qlik Open Lakehouse
Las fuentes de streaming tienen su propia arquitectura en Qlik Open Lakehouse, ya que no requieren la pasarela de datos Data Movement gateway para cargar datos en el depósito de destino, sino que funcionan con el clúster del lakehouse.
Cuando ingiere datos de archivos que incluyen un patrón de datos en el nombre del archivo, esto permite al clúster del lakehouse realizar operaciones de lista dirigidas en S3, lo que acelera drásticamente el tiempo de lectura de la lista de archivos. Además, Qlik Open Lakehouse puede predecir los archivos entrantes basándose en el patrón de fecha. La tarea de destino de streaming no tiene que mostrar todo el depósito cada vez, sino que puede solicitar los archivos de S3 dentro de un rango de fechas específico. Tener una lista de archivos más pequeña conduce a un mejor rendimiento. La configuración opcional Eliminar después de la carga se puede usar para mantener un recuento de archivos pequeño. No se realiza ninguna Carga completa, los primeros registros se consideran cambios insertados.
En un Qlik Open Lakehouse, la tarea de transformación de streaming reemplaza la tarea de almacenamiento. Esta tarea se utiliza para transformar y almacenar datos de destino como tablas Iceberg. Una tarea de transformación de streaming solo se puede añadir después de una tarea de destino de streaming. La tarea de transformación de streaming admite dos modos para actualizar registros:
- Solo anexar: agrega nuevos registros sin modificar los datos existentes y las restricciones de clave no se aplican si llegan registros duplicados.
-
Aplicar cambios (Combinar): actualiza los registros existentes e inserta nuevos registros basándose en campos clave. Este modo le ofrece la opción de usar una eliminación lógica o retener datos históricos (Tipo 2).
La tarea de transformación de streaming es una tarea basada en destino, que asocia entre origen y destino e incluye capacidades de evolución de esquema. Proporciona capacidades de transformación ampliadas, incluyendo la desanidación de estructuras anidadas y el aplanamiento de matrices. Para obtener más información sobre las funciones que puede utilizar en la tarea de transformación de streaming, consulte Funciones de transformación.
Cuando ingiere datos desde una fuente de transmisión o streaming, tiene la capacidad de configurar la partición de Iceberg, la gestión de retención, el orden de las columnas, la caducidad de las capturas para controlar los costes de almacenamiento y optimizar el rendimiento de las consultas.
Arquitectura para una canalización de datos en streaming de Qlik Open Lakehouse en modo solo anexar

Arquitectura para un proceso de datos de Qlik Open Lakehouse en modo de fusión

Tablas de destino
Los siguientes campos de cabecera se añaden a las tablas de destino. Estos campos siempre existen en los datos de destino, pero por defecto no en la transformación posterior. Puede añadir los campos a la transformación utilizando una expresión.
| Campo | Tipo | Descripción |
|---|---|---|
| hdr__kafka_partition | Long | Partición de Kafka |
| hdr__kafka_topic | Cadena | Tema de Kafka |
| hdr__kafka_offset | Long | Valor en ejecución en la partición |
| hdr__kafka_key | Cadena | Clave codificada en Base64. Establecer en cadena NULL si no está disponible. |
| hdr__kafka_headers | Cadena |
JSON con todos los encabezados de mensaje. Establecer en cadena NULL si no está disponible. |
| Campo | Tipo | Descripción |
|---|---|---|
| hdr__kinesis_stream | Cadena | Flujo de Amazon Kinesis |
| hdr__kinesis_shard | Cadena | Fragmento de Amazon Kinesis |
| hdr__kinesis_offset | Cadena | Desplazamiento de Amazon Kinesis |
| Campo | Tipo | Descripción |
|---|---|---|
| hdr__file_name | Cadena | Nombre de archivo |
| hdr__file_size | Long | Tamaño del archivo en bytes. |
Esquemas
Los artefactos se generan en un esquema interno y un esquema de tarea de datos.
-
El esquema interno contiene una tabla física con múltiples particiones.
-
El esquema de tarea de datos contiene las vistas que puede usar para consumir los datos.
Cuando un esquema de base de datos está asociada a más de una tarea de datos, cada tarea de datos ha de utilizar un prefijo único para tablas y vistas. Puede fijar el prefijo en la configuración de la tarea de datos.
Solo los esquemas internos se comprueban en busca de conflictos de nombres. Para otros esquemas, debe asegurarse de que no existan conflictos de denominación en los nombres de las tablas. La práctica recomendada es asignar al esquema interno el mismo nombre que al esquema de la tarea de datos y añadir _interno. Esto garantiza que cada combinación de esquema y prefijo sea única.
Tablas
Para cada tabla fuente, se crea una tabla en el esquema interno con el sufijo _internal, utilizando el formato:
<INTERNAL_SCHEMA>.<TABLE_NAME>_internal
Esta tabla contiene cinco particiones en modo Aplicar cambios (Combinar), cada una de las cuales cumple una función distinta en la forma en que se procesan y almacenan los datos. Cada partición aprovecha un subconjunto de columnas de la tabla en función de su papel en el ciclo de vida de los datos. En modo Solo anexar, la tabla no tiene particiones y se comporta como la partición Current (ODS).
El conjunto de datos interno está estructurado para gestionar eficazmente los datos entrantes de su sistema fuente, admitiendo la ingesta en tiempo real y el seguimiento histórico. El flujo de datos se gestiona a través de varias particiones especializadas, cada una de las cuales se describe a continuación:
-
La partición Changes – Ingesta en tiempo real
Todos los cambios del sistema fuente —inserciones, actualizaciones y eliminaciones— se añaden primero a la partición Changes.
-
Actuando como un registro de cambios en bruto, la partición proporciona una alimentación completa de la actividad de la fuente antes de que se produzca cualquier transformación.
-
Cada cambio se etiqueta con un tipo (I, U o D), que indica cómo se procesa.
-
Los eventos se capturan desde la fuente a medida que se producen. La partición se actualiza prácticamente en tiempo real.
-
La partición Changes está disponible cuando se aplican los siguientes ajustes en la tarea de aterrizaje de datos en el lago.
-
En la pestaña General, el método de actualización debe ser CDC.
-
La Carga completa debe estar activada.
-
-
-
La partición Asset_state - Seguimiento del progreso
A medida que se ingieren los cambios, la partición Asset_state registra dos marcas de tiempo clave:
-
Cuándo se añadieron por última vez los cambios a la partición Changes.
-
Cuándo se aplicaron por última vez los cambios a la partición Current.
Esto ofrece una visibilidad completa de toda la canalización o proceso de sincronización y ayuda a supervisar o solucionar los retrasos.
-
-
La partición Current (ODS) – Última réplica de la fuente
Los cambios de la partición Changes se aplican periódicamente a la partición Current a fin de mantener una copia actualizada y optimizada para consultas de los datos fuente.
-
Una tarea en segundo plano se ejecuta automáticamente para aplicar esas actualizaciones. Esto se basa en el volumen de cambios acumulados, más que en un calendario fijo definido.
-
La carga completa inicial se escribe directamente en la partición Current.
-
Esta partición refleja el estado actual de los datos y se ha diseñado para una consulta eficaz.
-
-
La partición Prior (HDS) – Datos históricos
Cuando se actualiza o elimina un registro en la partición Current, se escribe una copia de la versión anterior en la partición Prior.
-
Los registros contienen metadatos, incluido el historial de cambios y el intervalo de fechas en que los datos son válidos.
-
Esto es compatible con el tipo 2 de dimensión que cambia lentamente (SCD2).
-
La partición Prior está disponible cuando Conservar registros históricos y archivo de registros de cambios está activo en la pestaña General de la configuración de la tarea de almacenamiento de datos.
-
Cuando una versión actualizada de un registro entra en la partición Current, el registro anterior se traslada a la partición Prior para realizar un seguimiento histórico.
-
-
La partición Reload
La partición Reload actúa como un área de espera temporal durante las recargas completas manuales o programadas:
-
Los nuevos datos se escriben primero en la partición Reload.
-
Las tareas de mantenimiento regulares borran cualquier cambio pendiente antes de que se pongan en pausa.
-
Los datos se comparan con la partición Current y solo las diferencias se trasladan a la partición Current.
-
La partición Reload se borra cuando finaliza la operación.
Este proceso garantiza una interrupción mínima del conjunto de datos principal durante las operaciones de recarga completa.
-
La partición Current
| Campo | Tipo | Descripción |
|---|---|---|
| hdr__key_hash | VARBINARY (20) | Hash de todas las claves primarias del registro. El formato de hash es SHA1. Las columnas van separadas por un carácter de retroceso. |
| hdr__from_timestamp | TIMESTAMP |
Fecha-hora en UTC:
|
| hdr__operation | VARCHAR (1) |
Última operación de este registro.
|
| hdr__inserted_timestamp | TIMESTAMP | Marca de tiempo UTC de la primera vez que se agregó la clave. Cuando se usa carga completa, la hora de inicio de la carga completa. |
| hdr__modified_timestamp | TIMESTAMP | Fecha-hora UTC de cuando se realizó la última actualización. |
La partición Prior
| Campo | Tipo | Descripción |
|---|---|---|
| hdr__key_hash | VARBINARY (20) | Hash de todas las claves primarias del registro. |
| hdr__from_timestamp | TIMESTAMP | Fecha-hora en UTC. |
| hdr__to_timestamp | TIMESTAMP | Fecha-hora en UTC. |
| hdr__operation | STRING (1) |
Última operación de este registro.
|
| hdr__was_current_from_timestamp | TIMESTAMP | Fecha-hora en UTC de la primera vez que el registro fue actual. |
| hdr__was_current_to_timestamp | TIMESTAMP | Fecha-hora en UTC de la última vez que el registro fue actual. |
La partición Changes
| Campo | Tipo | Descripción |
|---|---|---|
| hdr__change_identifier | VARCHAR (50) |
El identificador de cambio es una cadena de caracteres con dos partes:
|
| hdr__operation | VARCHAR (1) |
Última operación de este registro.
|
| hdr__timestamp | TIMESTAMP | Fecha-hora en UTC. |
| hdr__key_hash | BINARY (20) | Hash de todas las claves primarias del registro. |
| hdr__inserted_timestamp | TIMESTAMP | Fecha-hora UTC del momento en que el cambio fue procesado por Qlik. |
La partición Asset_state
| Campo | Tipo | Descripción |
|---|---|---|
| hdr__apply_change_identifier | VARCHAR (50) | El identificador del último cambio aplicado a la partición Current. |
| hdr__copy_change_identifier | VARCHAR (50) | El identificador del último cambio añadido a la partición Changes. |
La partición Reload
Las columnas utilizadas por la partición Reload son idénticas a las de la partición Current.
Vistas
Todas las vistas creadas se actualizan casi en tiempo real. Las siguientes vistas están disponibles para simplificar la consulta y la elaboración de informes:
Actual
La vista Actual refleja el estado más reciente de los datos. Esta vista representa una réplica de la tabla de origen, actualizada prácticamente en tiempo real. Fusiona los datos de las particiones Current y Changes.
Nombre: <EXTERNAL_SCHEMA>.[<PREFIX>]<TABLE_NAME>
No se añaden columnas de cabecera a la estructura de la tabla.
Historial
Se genera una vista del Historial en el esquema del activo de datos para cada tabla de origen seleccionada cuando se activa el Historial en los ajustes de la tarea de datos. La vista de Historial fusiona los datos de las particiones Prior y Changes. Ofrece una cronología completa de los cambios, ideal para auditorías o análisis históricos.
Nombre: <EXTERNAL_SCHEMA>.[<PREFIX>]<TABLE_NAME>_<Suffix for history views>
Los siguientes campos de cabecera se añaden a la vista del Historial:
| Campo | Tipo | Descripción |
|---|---|---|
| hdr__key_hash | BINARY (20) | Hash de todas las claves primarias del registro. |
| hdr__from_timestamp | TIMESTAMP | La fecha-hora en que se produjo el cambio en el sistema fuente. Esto refleja el momento en que el usuario realizó el cambio originalmente. |
| hdr__to_timestamp | TIMESTAMP | La fecha-hora en que se anuló o actualizó el cambio en el sistema fuente. |
| hdr__store | VARCHAR (10) |
Indica dónde reside el registro:
|
| hdr__operation | STRING (1) |
Última operación de este registro.
|
| hdr__deleted | BIT | Indica si el registro se elimina temporalmente, en función de si la operación hdr__ es D o d. |
| hdr__was_current_from_timestamp | TIMESTAMP | La hora (UTC) en que esta fila entró en la partición Current. Esto suele ocurrir cuando se ejecuta el trabajo de almacenamiento y se aplica el cambio. |
| hdr__was_current_to_timestamp | TIMESTAMP | La hora (UTC) en que se eliminó la fila de la tabla Current, por ejemplo, debido a una versión más reciente. |