1

我正在通过以下方式使用融合版本 3.3.0 设置 ksql-cli

#zookeper
docker run -d -it \
    --net=host \
    --name=zookeeper \
    -e ZOOKEEPER_CLIENT_PORT=32181 \
    confluentinc/cp-zookeeper:3.3.0

#kafka
docker run -d \
    --net=host \
    --name=kafka \
    -e KAFKA_ZOOKEEPER_CONNECT=localhost:32181 \
    -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://localhost:29092 \
    -e KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR=1 \
    confluentinc/cp-kafka:3.3.0

#schema-registry
docker run -d \
  --net=host \
  --name=schema-registry \
  -e SCHEMA_REGISTRY_KAFKASTORE_CONNECTION_URL=localhost:32181 \
  -e SCHEMA_REGISTRY_HOST_NAME=localhost \
  -e SCHEMA_REGISTRY_LISTENERS=http://localhost:8081 \
  confluentinc/cp-schema-registry:3.3.0

我正在以下列方式运行 ksql-cli docker 映像

  docker run -it \
  --net=host \
  --name=ksql-cli \
  -e KSQL_CONFIG_DIR="/etc/ksql" \
  -e KSQL_LOG4J_OPTS="-Dlog4j.configuration=file:/etc/ksql/log4j-rolling.properties" \
  -e STREAMS_BOOTSTRAP_SERVERS=localhost:29092 \
  -e STREAMS_SCHEMA_REGISTRY_HOST=localhost \
  -e STREAMS_SCHEMA_REGISTRY_PORT=8081 \
  confluentinc/ksql-cli:0.5

当我ksql-cli通过以下方式进入容器的 bash运行时

docker exec -it ksql-cli bash

ksql-cli以下列方式运行:

./usr/bin/ksql-cli local

它给了我以下错误:

正在初始化 KSQL...

无法获取代理信息。KSQL 无法初始化 AdminCLient。

4

1 回答 1

2

默认情况下,ksql-cli 尝试连接到 localhost:9092 上的 Kafka 代理。看起来您的设置正在使用不同的端口,因此您需要在命令行上提供此端口,例如

./usr/bin/ksql-cli local --bootstrap-server localhost:32181

您可能还需要指定模式注册表端口,因此您可能需要使用属性文件,例如:

./usr/bin/ksql-cli local --properties-file ./ksql.properties

其中 ksql.properties 有:

bootstrap.servers=localhost:29092 schema.registry.url=localhost:8081

或者在命令行上同时提供:

./usr/bin/ksql-cli local \ --bootstrap-server localhost:29092 \ --schema.registry.url http://localhost:8081

请注意,从 KSQL 版本 4.1 开始,命令和属性会更改名称。 ksql-cli变得公正ksql。模式消失了local——你需要明确地运行一个或两个 ksql-server 节点。--property-file变成--config-fileschema.registry.url变成ksql.schema.registry.url

于 2018-04-12T16:46:20.953 回答