Python 引线不可用-docker容器

Python 引线不可用-docker容器,python,docker,apache-kafka,docker-compose,kafka-consumer-api,Python,Docker,Apache Kafka,Docker Compose,Kafka Consumer Api,设置docker容器(kafka、zookeeper)并尝试从另一个容器(发布和)消费时,收到以下错误: KafkaError{code=LEADER\u不可用,val=5,str=“Broker:LEADER不可用”} 发布或使用时没有其他错误指示。使用telnet 172.18.0.3 9092测试连接时,我收到了预期结果 In [2]: c.list_topics() Out[2]: ClusterMetadata(9ToJF8nPQC-rCTXGxuUalw) In [3]: l = c

设置docker容器(kafka、zookeeper)并尝试从另一个容器(发布和)消费时,收到以下错误: KafkaError{code=LEADER\u不可用,val=5,str=“Broker:LEADER不可用”} 发布或使用时没有其他错误指示。使用
telnet 172.18.0.3 9092测试连接时,我收到了预期结果

In [2]: c.list_topics()
Out[2]: ClusterMetadata(9ToJF8nPQC-rCTXGxuUalw)
In [3]: l = c.list_topics()
In [4]: l.brokers
Out[4]: {1010: BrokerMetadata(1010, 172.18.0.3:9092)}
In [7]: l.orig_broker_name
Out[7]: u'172.18.0.3:9092/1010'
In [8]: l.topics
Out[8]:
{'__consumer_offsets': TopicMetadata(__consumer_offsets, 50 partitions),
 'item': TopicMetadata(item, 1 partitions),
 'mytopic': TopicMetadata(mytopic, 1 partitions)}
In [9]: i  =l.topics['item']
In [10]: i.partitions
Out[10]: {0: PartitionMetadata(-1, KafkaError{code=LEADER_NOT_AVAILABLE,val=5,str="Broker: Leader not available"})}
docker compose.yml:

version: '2'
services:
  zookeeper:
    restart: always
    image: wurstmeister/zookeeper
    ports:
      - "2181:2181"
  kafka:
    restart: always
    depends_on:
      - zookeeper
    image: wurstmeister/kafka
    ports:
      - "9092:9092"
    environment:
      KAFKA_ADVERTISED_HOST_NAME: "172.18.0.3"
      KAFKA_ADVERTISED_PORT: "9092"
      KAFKA_CREATE_TOPICS: "item:1:1"
      KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
ubuntu@STAGE:~/docker/kafka#sudo docker网络检查kafka#u默认值

[
    {
        "Name": "kafka_default",
        "Id": "fc8afcde4318599b66f540ebd6221cffe57382a70b43ed1d58eda7fe059e7a18",
        "Created": "2018-07-25T13:29:56.034567548Z",
        "Scope": "local",
        "Driver": "bridge",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": null,
            "Config": [
                {
                    "Subnet": "172.18.0.0/16",
                    "Gateway": "172.18.0.1"
                }
            ]
        },
        "Internal": false,
        "Attachable": false,
        "Containers": {
            "7776db25d1ca9a3ec98775ff0dabe356409dda9f782a771c9b1f7ae4e04f3453": {
                "Name": "test",
                "EndpointID": "204158f6f167b12c06b2dcdda856992c5ea75adc80b06ac00f9abebb4f0179ba",
                "MacAddress": "02:42:ac:12:00:04",
                "IPv4Address": "172.18.0.4/16",
                "IPv6Address": ""
            },
            "b4869e44cf136a129701413c5a5dd371d15d6158bfaf577d30aeb6ad66b63263": {
                "Name": "kafka_zookeeper_1", DEPTH_PRIORITY = 1
                "EndpointID": "229b2587d92c8593d933d2583e09e669aa6f9a9c04e5b94ebf5a25be57aad27f",
                "MacAddress": "02:42:ac:12:00:02",
                "IPv4Address": "172.18.0.2/16",
                "IPv6Address": ""
            },
            "f682fd27ef52a40abf501348b5b16e59b48440041d1e4827ddb15a0ef8dbdd14": {
                "Name": "kafka_kafka_1",
                "EndpointID": "b17874d64c699635c471a1bcb515cb1441d22b2896e98a113115a4239caed460",
                "MacAddress": "02:42:ac:12:00:03",
                "IPv4Address": "172.18.0.3/16",
                "IPv6Address": ""
            }
        },
        "Options": {},
        "Labels": {}
    } ]

始终尝试在KAFKA_播发的主机名中使用公共ip,您可以使用KAFKA_主机名指定实例的主机名


如果您使用的是最新的卡夫卡版本,使用listeners和Adverted.listeners,而不是使用host.name和Adverted.host.name。

1)您是否尝试过使用汇合Docker映像2)仅仅因为您可以telnet并且端口已打开并不意味着Kafka协议已被禁用functional@cricket_007不,我不熟悉融合的Docker图像。你有链接吗?感谢您在DockerHub的Confluent下,具体到wurstmeister的图片,您可以在这里查看我的答案:(以及其他提示)一般来说,广告的主机名应该可以从容器外部访问如果您向不存在的主题发送消息,您会收到此错误。请看这里: