-
Notifications
You must be signed in to change notification settings - Fork 3.2k
Error handling
Magnus Edenhill edited this page Mar 22, 2016
·
6 revisions
Typically librdkafka hides any non-permanent errors from the application and handles them gracefully internally by retrying.
Permanent errors are handled in different ways:
- global errors, e.g., all brokers down, are passed to the error_cb and served through
rd_kafka_poll()
(e.g.RD_KAFKA_RESP_ERR__ALL_BROKERS_DOWN
). - Producer: message delivery failures (and success) are passed to the
dr_cb
/dr_msg_cb
callback and served throughrd_kafka_poll()
- Consumer: Consumer errors, such as mild notifications (
RD_KAFKA_RESP_ERR__PARTITION_EOF
) or more serious errors are passed asrkmessage->err
for the.._consume*()
functions that return or pass anrd_kafka_message_t
.
This means that a producer application should be calling rd_kafka_poll()
every now and then, and a consumer application should both consume messages and call rd_kafka_poll()
every now and then.
If using the new high-level KafkaConsumer an application should call rd_kafka_poll_set_consumer()
after creating the CONSUMER instance to automatically redirect all events to the single rd_kafka_consumer_poll()
queue endpoint.