本文整理匯總了Python中kafka.KafkaConsumer方法的典型用法代碼示例。如果您正苦於以下問題:Python kafka.KafkaConsumer方法的具體用法?Python kafka.KafkaConsumer怎麽用?Python kafka.KafkaConsumer使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類kafka
的用法示例。
在下文中一共展示了kafka.KafkaConsumer方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: _query_backend
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def _query_backend(self):
consumer = KafkaConsumer(
bootstrap_servers=KAFKA_HOST, value_deserializer=lambda v: JSONSerializer().loads(v.decode('utf-8'))
)
tp = TopicPartition(self.topic, 0)
consumer.assign([tp])
count = consumer.position(tp)
consumer.seek(tp, 0)
metrics = []
for i in range(count):
metrics.append(next(consumer))
return metrics
示例2: _create_consumer
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def _create_consumer(self):
"""Tries to establing the Kafka consumer connection"""
if not self.closed:
try:
self.logger.debug("Creating new kafka consumer using brokers: " +
str(self.settings['KAFKA_HOSTS']) + ' and topic ' +
self.settings['KAFKA_TOPIC_PREFIX'] +
".outbound_firehose")
return KafkaConsumer(
self.settings['KAFKA_TOPIC_PREFIX'] + ".outbound_firehose",
group_id=None,
bootstrap_servers=self.settings['KAFKA_HOSTS'],
consumer_timeout_ms=self.settings['KAFKA_CONSUMER_TIMEOUT'],
auto_offset_reset=self.settings['KAFKA_CONSUMER_AUTO_OFFSET_RESET'],
auto_commit_interval_ms=self.settings['KAFKA_CONSUMER_COMMIT_INTERVAL_MS'],
enable_auto_commit=self.settings['KAFKA_CONSUMER_AUTO_COMMIT_ENABLE'],
max_partition_fetch_bytes=self.settings['KAFKA_CONSUMER_FETCH_MESSAGE_MAX_BYTES'])
except KeyError as e:
self.logger.error('Missing setting named ' + str(e),
{'ex': traceback.format_exc()})
except:
self.logger.error("Couldn't initialize kafka consumer for topic",
{'ex': traceback.format_exc()})
raise
示例3: _create_consumer
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def _create_consumer(self):
"""Tries to establing the Kafka consumer connection"""
try:
brokers = self.settings['KAFKA_HOSTS']
self.logger.debug("Creating new kafka consumer using brokers: " +
str(brokers) + ' and topic ' +
self.settings['KAFKA_INCOMING_TOPIC'])
return KafkaConsumer(
self.settings['KAFKA_INCOMING_TOPIC'],
group_id=self.settings['KAFKA_GROUP'],
bootstrap_servers=brokers,
consumer_timeout_ms=self.settings['KAFKA_CONSUMER_TIMEOUT'],
auto_offset_reset=self.settings['KAFKA_CONSUMER_AUTO_OFFSET_RESET'],
auto_commit_interval_ms=self.settings['KAFKA_CONSUMER_COMMIT_INTERVAL_MS'],
enable_auto_commit=self.settings['KAFKA_CONSUMER_AUTO_COMMIT_ENABLE'],
max_partition_fetch_bytes=self.settings['KAFKA_CONSUMER_FETCH_MESSAGE_MAX_BYTES'])
except KeyError as e:
self.logger.error('Missing setting named ' + str(e),
{'ex': traceback.format_exc()})
except:
self.logger.error("Couldn't initialize kafka consumer for topic",
{'ex': traceback.format_exc(),
'topic': self.settings['KAFKA_INCOMING_TOPIC']})
raise
示例4: check_kafka_msg
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def check_kafka_msg(topic='events', nbr_msg=100):
## Collect Messages from Bus
consumer = KafkaConsumer(
bootstrap_servers=get_external_ip()+':'+str(KAFKA_BROKER_PORT),
auto_offset_reset='earliest')
consumer.subscribe([topic])
counter = 0
for message in consumer:
counter = counter + 1
if counter == nbr_msg:
break
return counter
示例5: pull_datapoints_from_kafka
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def pull_datapoints_from_kafka(self, kafka_config, stop_threads):
log.debug('Kafka datapoints puller thread starting..')
consumer = KafkaConsumer(
kafka_config['topic'],
group_id=kafka_config['group_id'],
bootstrap_servers=kafka_config['bootstrap_servers'])
while True and not stop_threads.isSet():
consumer.poll()
for message in consumer:
try:
json_message = json.loads(message.value.decode())
log.debug('Datapoint from kafka: %s', json_message)
if type(json_message) == list:
for datapoint in json_message:
self.register_datapoint(datapoint)
else:
self.register_datapoint(json_message)
except json.JSONDecodeError:
log.exception("Failed to decode message from Kafka, skipping..")
except Exception as e:
log.exception("Generic exception while pulling datapoints from Kafka")
log.debug('Kafka datapoints puller thread shutting down..')
示例6: run
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def run(self):
self.logger.info("start bot:{}".format(self))
funcs = set(dir(self)) & self.func_map_topic.keys()
consumer = KafkaConsumer(bootstrap_servers=[KAFKA_HOST])
current_topics = consumer.topics()
for func in funcs:
topic = self.func_map_topic.get(func)
if topic not in current_topics:
self.logger.exception("you implement func:{},but the topic:{} for it not exist".format(func, topic))
continue
self.threads.append(
threading.Thread(target=self.consume_topic_with_func, args=(self.func_map_topic.get(func), func)))
for the_thread in self.threads:
the_thread.start()
self.consume_topic_with_func(self.quote_topic, 'on_event')
self.logger.info("finish bot:{}".format(self))
示例7: run
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def run(self):
self.logger.info("start bot:{}".format(self))
funcs = set(dir(self)) & self.func_map_topic.keys()
consumer = KafkaConsumer(bootstrap_servers=[KAFKA_HOST])
current_topics = consumer.topics()
for func in funcs:
topic = self.func_map_topic.get(func)
if topic not in current_topics:
self.logger.exception("you implement func:{},but the topic:{} for it not exist".format(func, topic))
continue
self._threads.append(
threading.Thread(target=self.consume_topic_with_func, args=(self.func_map_topic.get(func), func)))
for the_thread in self._threads:
the_thread.start()
self.consume_topic_with_func(self.quote_topic, 'on_event')
self.logger.info("finish bot:{}".format(self))
示例8: run
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def run(self):
from kafka import KafkaConsumer
super().run()
self.consumer = KafkaConsumer(self.topic, bootstrap_servers=self.server)
self.logger.info('Initialized kafka backend - server: {}, topic: {}'
.format(self.server, self.topic))
try:
for msg in self.consumer:
self._on_record(msg)
if self.should_stop(): break
except Exception as e:
self.logger.warning('Kafka connection error, reconnecting in {} seconds'.
format(self._conn_retry_secs))
self.logger.exception(e)
time.sleep(self._conn_retry_secs)
# vim:sw=4:ts=4:et:
示例9: setup_class
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def setup_class(cls):
cls.broker = os.getenv('KAFKA_BROKER')
if not cls.topic:
topic = "%s-%s" % ('topic_test_', random_string(10))
cls.topic = topic
create_topic(cls.topic)
cls._deserializer = ScrapyJSONDecoder()
cls.consumer = KafkaConsumer(
bootstrap_servers=[cls.broker],
auto_offset_reset='earliest',
group_id=None,
value_deserializer=lambda x:
cls._deserializer.decode(x.decode('utf8'))
)
cls.consumer.subscribe([cls.topic])
示例10: getOffsets
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def getOffsets(self, topic, partitions, group):
""" 指定topic、partition和group, 返回offsets數據 """
try:
# 嘗試使用zookeeper-storage api獲取offsets數據
# 未獲得指定group的offsets數據將拋出UnknownTopicOrPartitionError異常
tp = self.client.send_offset_fetch_request(group, [OffsetRequestPayload(topic, p, -1, 1) for p in partitions])
offsets = {p.partition: p.offset for p in tp}
except UnknownTopicOrPartitionError:
# 收到異常後使用kafka-storage api獲取offsets數據
consumer = KafkaConsumer(group_id=group, bootstrap_servers=self.broker, enable_auto_commit=False)
tp = [TopicPartition(topic, p) for p in partitions]
consumer.assign(tp)
offsets = {p.partition: consumer.position(p) for p in tp}
return offsets
示例11: test_worker_properties
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def test_worker_properties(worker, hosts, topic, group):
assert hosts in repr(worker)
assert topic in repr(worker)
assert group in repr(worker)
assert worker.consumer.config['bootstrap_servers'] == hosts
assert worker.consumer.config['group_id'] == group
assert isinstance(worker.hosts, str) and worker.hosts == hosts
assert isinstance(worker.topic, str) and worker.topic == topic
assert isinstance(worker.group, str) and worker.group == group
assert isinstance(worker.consumer, KafkaConsumer)
assert callable(worker.deserializer)
assert callable(worker.callback) or worker.callback is None
# noinspection PyTypeChecker
示例12: test_worker_initialization_with_bad_args
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def test_worker_initialization_with_bad_args(hosts, consumer):
with pytest.raises(AssertionError) as e:
Worker(topic=True, consumer=consumer)
assert str(e.value) == 'topic must be a str'
with pytest.raises(AssertionError) as e:
Worker(topic='topic', consumer='bar')
assert str(e.value) == 'bad consumer instance'
with pytest.raises(AssertionError) as e:
bad_consumer = KafkaConsumer(bootstrap_servers=hosts)
Worker(topic='topic', consumer=bad_consumer)
assert str(e.value) == 'consumer must have group_id'
with pytest.raises(AssertionError) as e:
Worker(topic='topic', consumer=consumer, callback=1)
assert str(e.value) == 'callback must be a callable'
with pytest.raises(AssertionError) as e:
Worker(topic='topic', consumer=consumer, deserializer=1)
assert str(e.value) == 'deserializer must be a callable'
with pytest.raises(AssertionError) as e:
Worker(topic='topic', consumer=consumer, logger=1)
assert str(e.value) == 'bad logger instance'
示例13: debug
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def debug(self, topic):
c=KafkaConsumer(bootstrap_servers=kafka_hosts, client_id=self._client_id , group_id=None, api_version=(0,10))
# assign/subscribe topic
partitions=c.partitions_for_topic(topic)
if not partitions: raise Exception("Topic "+topic+" not exist")
c.assign([TopicPartition(topic,p) for p in partitions])
# seek to beginning if needed
c.seek_to_beginning()
# fetch messages
while True:
partitions=c.poll(100)
if partitions:
for p in partitions:
for msg in partitions[p]:
yield msg.value.decode('utf-8')
yield ""
c.close()
示例14: create_kafka_consumer
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def create_kafka_consumer(self, fetch_min_bytes, group_name, internal_name, request_data):
while True:
try:
c = KafkaConsumer(
bootstrap_servers=self.config["bootstrap_uri"],
client_id=internal_name,
security_protocol=self.config["security_protocol"],
ssl_cafile=self.config["ssl_cafile"],
ssl_certfile=self.config["ssl_certfile"],
ssl_keyfile=self.config["ssl_keyfile"],
group_id=group_name,
fetch_min_bytes=fetch_min_bytes,
fetch_max_bytes=self.config["consumer_request_max_bytes"],
request_timeout_ms=request_data["consumer.request.timeout.ms"],
enable_auto_commit=request_data["auto.commit.enable"],
auto_offset_reset=request_data["auto.offset.reset"]
)
return c
except: # pylint: disable=bare-except
self.log.exception("Unable to create consumer, retrying")
await asyncio.sleep(1)
示例15: start_data_processing
# 需要導入模塊: import kafka [as 別名]
# 或者: from kafka import KafkaConsumer [as 別名]
def start_data_processing(thread_number):
# open consumer
consumer = KafkaConsumer(**agent_config_vars['kafka_kwargs'])
logger.info('Started consumer number ' + str(thread_number))
# subscribe to given topics
consumer.subscribe(agent_config_vars['topics'])
logger.info('Successfully subscribed to topics' + str(agent_config_vars['topics']))
# start consuming messages
parse_messages_kafka(consumer)
consumer.close()
logger.info('Closed consumer number ' + str(thread_number))