2016-05-17 63 views
1

Ich schreibe einen einfachen Code in Python 2.7, der Messaging von einem Apache Kafka Thema verbraucht. Der Code ist die folgende:kafka-python raisen kafka.errors.ConsumerFetchSizeTooSmall

from kafka import SimpleConsumer,KafkaClient 
group = "my_group_test" 
client = KafkaClient('localhost:9092') 
cons = SimpleConsumer(client, group, "my_topic") 
messages = cons.get_messages(count=1000,block=False) 

aber hebt diese Ausnahme:

Traceback (most recent call last): 
    File "<stdin>", line 1, in <module> 
    File "/usr/local/lib/python2.7/dist-packages/kafka/consumer/simple.py", line 285, in get_messages 
    update_offset=False) 
    File "/usr/local/lib/python2.7/dist-packages/kafka/consumer/simple.py", line 320, in _get_message 
    self._fetch() 
    File "/usr/local/lib/python2.7/dist-packages/kafka/consumer/simple.py", line 425, in _fetch 
    raise ConsumerFetchSizeTooSmall() 
kafka.errors.ConsumerFetchSizeTooSmall 

Wie kann ich diesen Parameter ändern (ConsumerFetchSize), um diesen Code Arbeit zu machen?

Antwort

0

Ich fand eine Lösung, mit dem Parameter max_buffer_size im SimpleConsumer.

Der Arbeitscode lautet:

#the size is adherent with my need but is totally arbitrary 
cons = SimpleConsumer(client, group, "my_topic",max_buffer_size=9932768)