1.kafka.errors.UnsupportedCodecError: UnsupportedCodecError: Libraries for snappy compression codec not found
当不存在处理 Snappy 解压缩的模块时,KafkaConsumer 不会返回任何消息,而不是报告问题。 这与传统的 Consumer API 不同,后者提供了更有用的错误消息。
在使用 Kafka 消费者时,处理 Snappy 压缩的模块通常会在以下情况下发挥作用:
-
消息生产者使用 Snappy 压缩: 如果消息生产者使用了 Snappy 压缩算法来压缩消息,那么在消息被发送到 Kafka 之后,Kafka 会将其存储为 Snappy 压缩格式。当消费者从 Kafka 中拉取消息时,它们需要能够解压缩这些消息。因此,消费者的代码中会包含 Snappy 解压缩的模块,以确保能够正确地处理压缩过的消息。
-
消费者配置启用了 Snappy 解压缩: 在消费者的配置中,可能会设置参数以启用 Snappy 解压缩。例如,在 Kafka 消费者配置中,
compression.type
参数用于指定消息的压缩类型,如果该参数的值是 "snappy",那么消费者将期望收到 Snappy 压缩的消息,并相应地解压缩它们。
解决方法:
pip install python-snappy
相关连接:
https://stackoverflow.com/questions/39669024/kafka-python-consumer-giving-errors
Help: snappy decompression broken? · Issue #751 · dpkp/kafka-python · GitHub