Overview
Utilice las siguientes opciones de configuración para especificar cómo el conector de receptor MongoDB Kafka maneja los errores y para configurar la cola de mensajes no entregados.
Para obtener una lista de las configuraciones del conector del fregadero organizadas por categoría, consulte la guía en Propiedades de configuración del conector del sumidero.
Configuraciones
Nombre | Descripción |
|---|---|
mongo.errors.tolerance | Type: string Description: Whether to continue processing messages if the connector encounters
an error. Allows the connector to override the errors.tolerance
Kafka cluster setting.When set to none, the connector reports any error and
blocks further processing of the rest of the messages.When set to all, the connector ignores any problematic messages.When set to data, the connector tolerates only data errors and
fails on all other errors.To learn more about error handling strategies, see the
Handle Errors page. This property overrides the errors.tolerance property of the Connect Framework. Default: Inherits the value from the errors.tolerance
setting.Accepted Values: "none" or "all" |
mongo.errors.log.enable | Type: boolean Description: Whether the connector should write details of errors including
failed operations to the log file. The connector classifies
errors as "tolerated" or "not tolerated" using the
errors.tolerance or mongo.errors.tolerance settings.When set to true, the connector logs both "tolerated" and
"not tolerated" errors.When set to false, the connector logs "not tolerated" errors.This property overrides the errors.log.enable property of the Connect Framework. Default: falseAccepted Values: true or false |
errors.log.include.messages | Type: boolean Description: Whether the connector should include the invalid message when
logging an error. An invalid message includes data such as record
keys, values, and headers. Default: falseAccepted Values: true or false |
errors.deadletterqueue.topic.name | Type: string Description: Name of topic to use as the dead letter queue. If blank, the
connector does not send any invalid messages to the dead letter
queue. To learn more about the dead letter queue, see the
Dead Letter Queue Configuration Example. Default: ""Accepted Values: A valid Kafka topic name |
errors.deadletterqueue.context.headers.enable | Type: boolean Description: Whether the connector should include context headers when it
writes messages to the dead letter queue. To learn more about the dead letter queue, see the
Dead Letter Queue Configuration Example. To learn about the exceptions the connector defines and
reports through context headers, see
Bulk Write Exceptions. Default: falseAccepted Values: true or false |
errors.deadletterqueue.topic.replication.factor | Type: integer Description: The number of nodes on which to replicate the dead letter queue
topic. If you are running a single-node Kafka cluster, you must
set this to 1.To learn more about the dead letter queue, see the
Dead Letter Queue Configuration Example. Default: 3Accepted Values: A valid number of nodes |
Excepciones de escritura masiva
El conector puede informar las siguientes excepciones a su cola de mensajes no entregados como encabezados de contexto al realizar escrituras masivas:
Nombre | Descripción | |
|---|---|---|
WriteException | Esta clase genera el error en el siguiente formato: Los campos en el mensaje anterior contienen la siguiente información:
| |
WriteConcernException | Esta clase genera el error en el siguiente formato: Los campos en el mensaje anterior contienen la siguiente información:
| |
WriteSkippedException | Description: Informs that MongoDB did not attempt the write of a SinkRecord as part of
the following scenario:
To learn how to set the connector to perform unordered bulk
write operations, see the Connector Message Processing Properties page. Message Format: Esta excepción no produce ningún mensaje. |
Para habilitar el reporte de excepciones de guardado masivo en la fila de letra muerta, utiliza la siguiente configuración del conector:
errors.tolerance=all errors.deadletterqueue.topic.name=<name of topic to use as dead letter queue> errors.deadletterqueue.context.headers.enable=true
Ejemplo de configuración de cola de mensajes no entregados
La versión de Apache Kafka 2.6 agregó compatibilidad con el manejo de registros erróneos. El conector de Kafka envía automáticamente los mensajes que no puede procesar a la cola de mensajes no entregados. Una vez en la cola de mensajes no entregados, puede inspeccionar los registros erróneos, actualizarlos y reenviarlos para su procesamiento.
A continuación, se muestra un ejemplo de configuración para habilitar el tema example.deadletterqueue de la cola de mensajes no entregados. Esta configuración especifica que la cola de mensajes no entregados y el archivo de registro deben registrar los mensajes no válidos, y que los mensajes de la cola de mensajes no entregados deben incluir encabezados de contexto.
mongo.errors.tolerance=all mongo.errors.log.enable=true errors.log.include.messages=true errors.deadletterqueue.topic.name=example.deadletterqueue errors.deadletterqueue.context.headers.enable=true
Para obtener más información sobre las colas de mensajes no entregados, consulte Escribir errores y mensajes erróneos en un tema.