一.部署
- pull wurstmeister/zookeeper
sudo docker pull wurstmeister/zookeeper
- pull wurstmeister/kafka
sudo docker pull wurstmeister/kafka
- 啟動zookeeper
sudo docker run -d --name zookeeper -p 2181:2181 -t wurstmeister/zookeeper
- 啟動kafka
sudo docker run -d -t --name kafka -p 9092:9092 -e KAFKA_BROKER_ID=0 -e KAFKA_ZOOKEEPER_CONNECT=192.168.18.166:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://192.168.18.166:9092 -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092 wurstmeister/kafka
- server.properties 修改num.partitions=2 ,表示2個分區
num.partitions=2
- 重啟kafka container
二.兩個group 消費分區消費
- product
import json
from kafka import KafkaProducer
def sendMsg(topic,msg_dict):
producer = KafkaProducer(bootstrap_servers=["192.168.18.166:9092"],value_serializer=lambda v: json.dumps(v).encode('utf-8'))
'''send json String to kafka '''
producer.send(topic, msg_dict)
producer.close()
if __name__ == '__main__':
for i in range(10):
sendMsg("peter.test1",str(str(i)+'11'))
print("over"+str(str(i)+'10'))
sendMsg("json",msg_dict)
- 兩個consumer指定分區消費,,如果不指定分區,則消費全部消息
#consumer 1
from kafka import KafkaConsumer
import logging
import json
import datetime
from kafka import TopicPartition
def main():
#consumer = KafkaConsumer( "peter.test_cluser",group_id="peter_consumer_cluser3", max_poll_records=5, max_poll_interval_ms=600000,
consumer = KafkaConsumer( group_id="peter_consumer_cluser1", max_poll_records=5, max_poll_interval_ms=600000,
#enable_auto_commit =False,
bootstrap_servers=["192.168.18.166:9092"], value_deserializer=json.loads)
print("start consumer",str(consumer))
consumer.assign([TopicPartition('peter.test1', 0)]) # 指定topic 和指定分區消費
for message in consumer:
# print(str(message.offset()))
print("receive label message")
if message:
try:
print("@@@@@ ---> consumer_cluser1 get new message ",str(message.value))
#consumer.commit()
except Exception as e:
logging.error("@@----> Exception : ")
logging.error(e)
traceback.print_exc()
if __name__ == '__main__':
main()
consumer2
from kafka import KafkaConsumer
import logging
import json
import datetime
from kafka import TopicPartition
def main():
#consumer = KafkaConsumer( "peter.test_cluser",group_id="peter_consumer_cluser3", max_poll_records=5, max_poll_interval_ms=600000,
consumer = KafkaConsumer( group_id="peter_consumer_cluser2", max_poll_records=5, max_poll_interval_ms=600000,
#enable_auto_commit =False,
bootstrap_servers=["192.168.18.166:9092"], value_deserializer=json.loads)
print("start consumer",str(consumer))
consumer.assign([TopicPartition('peter.test1', 1)])# 指定topic 和指定分區消費
for message in consumer:
# print(str(message.offset()))
print("receive label message")
if message:
try:
print("@@@@@ ---> consumer_cluser1 get new message ",str(message.value))
#consumer.commit()
except Exception as e:
logging.error("@@----> Exception : ")
logging.error(e)
traceback.print_exc()
if __name__ == '__main__':
main()