Saltar al contenido principal

Fuentes de datos compatibles

NombreLogoTipoEstadoDescripción
Apache Kafkalogo de Apache KafkaStreamingEstableConfigure ClickPipes y comience a ingestar datos en streaming desde Apache Kafka a ClickHouse Cloud.
Confluent Cloudlogo de Confluent CloudStreamingEstableAproveche la potencia combinada de Confluent y ClickHouse Cloud mediante nuestra integración directa.
Redpandalogo de RedpandaStreamingEstableConfigure ClickPipes y comience a ingestar datos en streaming desde Redpanda a ClickHouse Cloud.
AWS MSKlogo de AWS MSKStreamingEstableConfigure ClickPipes y comience a ingestar datos en streaming desde AWS MSK a ClickHouse Cloud.
Azure Event Hubslogo de Azure Event HubsStreamingEstableConfigure ClickPipes y comience a ingestar datos en streaming desde Azure Event Hubs a ClickHouse Cloud.
WarpStreamlogo de WarpStreamStreamingEstableConfigure ClickPipes y comience a ingestar datos en streaming desde WarpStream a ClickHouse Cloud.

Formatos de datos admitidos

Los formatos admitidos son:

Tipos de datos compatibles

Tipos estándar

Actualmente, ClickPipes admite los siguientes tipos de datos estándar de ClickHouse:
  • Tipos numéricos básicos: [U]Int8/16/32/64, Float32/64 y BFloat16
  • Tipos enteros grandes: [U]Int128/256
  • Tipos Decimal
  • Boolean
  • String
  • FixedString
  • Date, Date32
  • DateTime, DateTime64 (solo zonas horarias UTC)
  • Enum8/Enum16
  • UUID
  • IPv4
  • IPv6
  • Time, Time64
  • JSON
  • todos los tipos LowCardinality de ClickHouse
  • Map con claves y valores que usan cualquiera de los tipos anteriores (incluidos los Nullable)
  • Tuple y Array con elementos que usan cualquiera de los tipos anteriores (incluidos los Nullable, solo un nivel de profundidad)
  • tipos SimpleAggregateFunction (para destinos AggregatingMergeTree o SummingMergeTree)

Compatibilidad con el tipo Variant

ClickPipes admite el tipo Variant en las siguientes circunstancias:
  • Unions de Avro. Si su esquema de Avro contiene una unión con varios tipos no nulos, ClickPipes inferirá el tipo Variant adecuado. En otros casos, los tipos Variant no se admiten para datos Avro.
  • Campos JSON. Puede especificar manualmente un tipo Variant (como Variant(String, Int64, DateTime)) para cualquier campo JSON en el flujo de datos de origen. No se admiten subtipos complejos (arrays/maps/tuples). Además, debido a la forma en que ClickPipes determina el subtipo Variant correcto que debe usar, en la definición de Variant solo puede usarse un tipo entero o de fecha y hora; por ejemplo, Variant(Int64, UInt32) no se admite.

Compatibilidad con el tipo JSON

ClickPipes admiten el tipo JSON en los siguientes casos:
  • Los campos Avro Record y Protobuf Message siempre se pueden asignar a una columna JSON.
  • Los campos Avro String y Bytes se pueden asignar a una columna JSON si el campo Avro contiene realmente cadenas JSON que representan objetos.
  • Los campos Protobuf de tipo String y Bytes se pueden asignar a una columna JSON si el campo Protobuf contiene realmente cadenas JSON que representan objetos.
  • Los campos JSON que siempre son un objeto JSON se pueden asignar a una columna JSON de destino.
Ten en cuenta que tendrás que cambiar manualmente la columna de destino al tipo JSON deseado, incluidas las rutas fijas o omitidas.

Avro

Tipos de datos Avro compatibles

ClickPipes admite todos los tipos primitivos y complejos de Avro, así como todos los tipos lógicos de Avro, excepto local-timestamp-millis y local_timestamp-micros. Los tipos record de Avro se convierten en Tuple, los tipos array en Array y map en Map (solo claves de cadena). En general, están disponibles las conversiones indicadas aquí. Recomendamos usar una correspondencia exacta de tipos para los tipos numéricos de Avro, ya que ClickPipes no comprueba el overflow ni la pérdida de precisión durante la conversión de tipos. Como alternativa, todos los tipos de Avro se pueden insertar en una columna String y, en ese caso, se representarán como una cadena JSON válida.

Tipos Nullable y uniones de Avro

Los tipos Nullable en Avro se definen mediante un esquema union de (T, null) o (null, T), donde T es el tipo base de Avro. Durante la inferencia de esquemas, estas uniones se asignan a una columna “Nullable” de ClickHouse. Ten en cuenta que ClickHouse no admite los tipos Nullable(Array), Nullable(Map) ni Nullable(Tuple). Las uniones con null de Avro para estos tipos se asignan a versiones no anulables (los tipos Record de Avro se asignan a un Tuple con nombre de ClickHouse). Los valores “null” de Avro para estos tipos se insertarán como:
  • Un Array vacío para un array de Avro nulo
  • Un Map vacío para un Map de Avro nulo
  • Un Tuple con nombre con todos los valores predeterminados o cero para un Record de Avro nulo

Protobuf

Tipos de datos de Protobuf compatibles

ClickPipes admite todos los tipos de Protobuf 2 y 3, excepto el tipo group de proto 2, que lleva tiempo obsoleto. Las conversiones básicas de tipos usan las siguientes correspondencias:
También se admiten las variantes Array, Map y Nullable de todos los tipos básicos.
Tipo de ProtobufTipo de ClickHouse
boolUInt8
floatFloat32
doubleFloat64
int32, sint32, sfixed32Int32
int64, sint64, sfixed64Int64
uint32, fixed32UInt32
uint64, fixed64UInt64
string, bytesString
enumEnum
repeated TArray(T)
messageTuple
Para los tipos numéricos, se recomienda una correspondencia exacta para evitar desbordamientos o pérdida de precisión.
También se admiten los siguientes tipos conocidos:
Tipo conocidoTipo de ClickHouse
google.protobuf.TimestampDateTime, DateTime64
google.protobuf.DurationTime, Time64
google.protobuf.StringValue, google.protobuf.BytesValueNullable(String)
google.protobuf.Int32Value, google.protobuf.SInt32Value, google.protobuf.SFixed32ValueNullable(Int32)
google.protobuf.Int64Value, google.protobuf.SInt64Value, google.protobuf.SFixed64ValueNullable(Int64)
google.protobuf.UInt32Value, google.protobuf.Fixed32ValueNullable(UInt32)
google.protobuf.UInt64Value, google.protobuf.Fixed64ValueNullable(UInt64)
google.protobuf.FloatValueNullable(Float32)
google.protobuf.DoubleValueNullable(Float64)
google.protobuf.BoolValueNullable(UInt8)

Protobuf oneof

Durante la inferencia de esquemas, los campos oneof de Protobuf se asignan de forma predeterminada a un Tuple con nombre, donde como máximo un campo contendrá un valor distinto del predeterminado. Estos campos también pueden asignarse automáticamente a una columna Variant, donde el valor activo adopta el tipo del campo constituyente que esté establecido. Como alternativa, cada campo constituyente puede asignarse manualmente a su propia columna de ClickHouse; dado que los campos oneof son mutuamente excluyentes, solo se rellenará una columna por registro.

Listas de mensajes

Si el esquema Protobuf de nivel superior definido para el ClickPipe contiene un único campo repetido que a su vez es un Message de protobuf, la inferencia de esquemas y la asignación de columnas se basarán en el campo Message «contenido». El mensaje de Kafka se procesará como una lista de esos mensajes, y un único mensaje de Kafka se desglosará en múltiples filas de ClickHouse.

Columnas virtuales de Kafka

Las siguientes columnas virtuales son compatibles con las fuentes de datos de streaming compatibles con Kafka. Al crear un nuevo destino, se pueden añadir columnas virtuales a la tabla de destino mediante el botón Add Column.
NombreDescripciónTipo de dato recomendado
_keyClave del mensaje de KafkaString
_timestampMarca temporal de Kafka (precisión de milisegundos)DateTime64(3)
_partitionPartición de KafkaInt32
_offsetOffset de KafkaInt64
_topicTopic de KafkaString
_header_keysArray paralelo de claves en las cabeceras del registroArray(String)
_header_valuesArray paralelo de valores en las cabeceras del registroArray(String)
_raw_messageMensaje completo de KafkaString
Ten en cuenta que la columna _raw_message solo se recomienda para datos JSON. En los casos de uso en los que solo se necesita la cadena JSON (por ejemplo, al usar las funciones JsonExtract* de ClickHouse para poblar una vista materializada de destino), eliminar todas las columnas “no virtuales” puede mejorar el rendimiento de ClickPipes.
Última modificación el 10 de junio de 2026