zoukankan      html  css  js  c++  java
  • docker kafka 集群部署,单zookeeper

    一. 部署

    1. pull wurstmeister/zookeeper
    sudo docker pull wurstmeister/zookeeper
    
    1. pull wurstmeister/kafka
    sudo docker pull wurstmeister/kafka
    
    1. 启动zookeeper
    sudo docker run -d --name zookeeper -p 2181:2181 -t  wurstmeister/zookeeper
    
    1. 启动kafka1
    sudo docker run  -d -t --name kafka1 -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
    
    1. 启动kafka2
      noted: -p 9093:9092 端口必须如此设置,不然会导致连接不到kafka2
    sudo docker run  -d -t --name kafka2 -p 9093:9092 -e KAFKA_BROKER_ID=1 -e KAFKA_ZOOKEEPER_CONNECT=192.168.18.166:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://192.168.18.166:9093 -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9093  wurstmeister/kafka
    
    1. 两个kafka中server.properties 修改num.partitions=2 ,表示2个分区
    # 两个分区
    num.partitions=2 
    # 两个副本
    offsets.topic.replication.factor=2                                                                                              
    transaction.state.log.replication.factor=2
    
    1. 重启kafka container

    二:两个group 消费

    1. product
    import json
    from kafka import KafkaProducer
    
    
    def sendMsg(topic,msg_dict):
        producer = KafkaProducer(bootstrap_servers=["192.168.18.166:9092","192.168.18.166:9093"],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.test_cluser",str(str(i)+'11'))
            print("over"+str(str(i)+'10'))
            sendMsg("json",msg_dict)
    
    1. 两个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","192.168.18.166:9093"], value_deserializer=json.loads)
            print("start consumer",str(consumer)) 
            consumer.assign([TopicPartition('peter.test_cluser', 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","192.168.18.166:9093"], value_deserializer=json.loads)
            print("start consumer",str(consumer)) 
            consumer.assign([TopicPartition('peter.test_cluser', 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()
    

    三. 同一个组,两个consumer交替消费

    1. product 同上中的
    2. 两个consumer 使用同一个group
      consumer1:
    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","192.168.18.166:9093"], value_deserializer=json.loads)
            print("start consumer",str(consumer)) 
            #consumer.assign([TopicPartition('peter.test_cluser', 1)])
            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","192.168.18.166:9093"], value_deserializer=json.loads)
            print("start consumer",str(consumer)) 
            #consumer.assign([TopicPartition('peter.test_cluser', 1)])
            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()
    
  • 相关阅读:
    laravel 使用DB 鏈接leftJoin查詢
    checkbox复选框,如何让其勾选时触发一个事件,取消勾选时不触发
    js获取上传图片大小,判断上传图片类型,获取图片真实宽度和高度
    如何查看crontab的日志记录
    linux应用之gcc环境的安装
    laravel 获取上一条insert语句产生的id
    laravel多条件查询(and,or嵌套查询)
    laravel ORM 模型关联 with () 用法
    js实现表单提交 onsubmit
    如何利用jquery来给input添加或删除disabled属性
  • 原文地址:https://www.cnblogs.com/wanthune/p/12672597.html
Copyright © 2011-2022 走看看