使用Docker/Docker Compose 快捷安装Kafka

作者:沈自在

img

1 Docker 安装

1.1 编写 Docker compose 文件

通过 docker compose 便捷安装 Kafka 以及 Kafka UI

version: "3"
services:
  kafka:
    image: 'bitnami/kafka:latest'
    container_name: kafka
    ports:
      - "9092:9092"
      - "9093:9093"
    volumes:
      - type: volume
        source: kafka_standalone_data
        target: /bitnami/kafka
        read_only: false
    environment:
      - BITNAMI_DEBUG=yes
      # 启用KRaft模式必须设置下面三个属性
      - KAFKA_CFG_NODE_ID=1
      - KAFKA_CFG_PROCESS_ROLES=broker,controller
      - KAFKA_CFG_CONTROLLER_LISTENER_NAMES=CONTROLLER
      # broker id
      - KAFKA_BROKER_ID=1
      # listener的各种配置
      - KAFKA_CFG_LISTENERS=CONTROLLER://:9094,BROKER://:9092,EXTERNAL://:9093
      - KAFKA_CFG_LISTENER_SECURITY_PROTOCOL_MAP=CONTROLLER:PLAINTEXT,BROKER:PLAINTEXT,EXTERNAL:PLAINTEXT
      # 注意EXTERNAL配置的是当前Docker所在的主机地址,BROKER可以使用Docker内部的网络地址即可
      - KAFKA_CFG_ADVERTISED_LISTENERS=BROKER://kafka:9092,EXTERNAL://192.168.0.101:9093
      # 内部各个broker之间通信用的listener
      - KAFKA_CFG_INTER_BROKER_LISTENER_NAME=BROKER
      # 用来进行选举的Controller服务器,如果有多个Controller则都需要写上,这里本机
      - KAFKA_CFG_CONTROLLER_QUORUM_VOTERS=1@127.0.0.1:9094
      - ALLOW_PLAINTEXT_LISTENER=yes
  kafka-ui:
    container_name: kafka-ui
    image: provectuslabs/kafka-ui:latest
    ports:
      - "9095:8080"
    depends_on:
      - kafka
    environment:
      KAFKA_CLUSTERS_0_NAME: kafka-stand-alone
      KAFKA_CLUSTERS_0_BOOTSTRAPSERVERS: kafka:9092
      KAFKA_CLUSTERS_0_METRICS_PORT: 9997
      SERVER_SERVLET_CONTEXT_PATH: /kafkaui
      AUTH_TYPE: "LOGIN_FORM"
      SPRING_SECURITY_USER_NAME: admin
      SPRING_SECURITY_USER_PASSWORD: thr010410
      DYNAMIC_CONFIG_ENABLED: 'true'
volumes:
  kafka_standalone_data:
    driver: local

1.2 启动构建

只需要在该文件所在的目录下,执行该命令即可:

docker-compose -f docker-compose.yml up -d

1.3 访问页面

http://localhost:9095/kafkaui/auth
  • 9
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 可以使用以下步骤在 Docker Compose安装 Kafka: 1. 创建一个 `docker-compose.yml` 文件,并在其中定义 Kafka 和 Zookeeper 服务。以下是一个示例文件: ``` version: '2' services: zookeeper: image: wurstmeister/zookeeper ports: - "2181:2181" kafka: image: wurstmeister/kafka ports: - "9092:9092" environment: KAFKA_ADVERTISED_HOST_NAME: localhost KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181 ``` 2. 运行以下命令启动 Kafka 和 Zookeeper 服务: ``` docker-compose up -d ``` 3. 等待一段时间,直到服务启动完成。可以使用以下命令检查服务状态: ``` docker-compose ps ``` 4. 您现在可以使用 Kafka 生产和消费消息。可以使用以下命令运行 Kafka 生产者: ``` docker-compose exec kafka bash -c "echo 'test-message' | kafka-console-producer.sh --broker-list localhost:9092 --topic test-topic" ``` 5. 可以使用以下命令运行 Kafka 消费者: ``` docker-compose exec kafka bash -c "kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic test-topic --from-beginning" ``` 这样,您就可以在 Docker Compose安装使用 Kafka 了。 ### 回答2: 要安装 KafkaDocker Compose,您需要按照以下步骤进行操作: 1. 首先,在您的计算机上安装 DockerDocker Compose。您可以从 Docker 官方网站下载并安装适用于您操作系统的 Docker 版本。 2. 下载 Kafka Docker 镜像。您可以在 Docker Hub 上找到官方的 Kafka 镜像。可以使用以下命令下载 Kafka 镜像:docker pull wurstmeister/kafka。 3. 创建一个 Docker Compose 配置文件。在您的工作目录中创建一个名为 `docker-compose.yml` 的文件,并在其中定义 Kafka 服务。示例配置文件如下: ```yaml version: '3' services: zookeeper: image: wurstmeister/zookeeper ports: - "2181:2181" kafka: image: wurstmeister/kafka ports: - "9092:9092" environment: - KAFKA_ADVERTISED_HOST_NAME=kafka - KAFKA_ADVERTISED_PORT=9092 - KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181 - KAFKA_CREATE_TOPICS=test-topic:1:1 depends_on: - zookeeper ``` 在上述示例中,我们定义了一个名为 Zookeeper 的服务和一个名为 Kafka 的服务。我们将 Zookeeper 服务映射到主机的端口2181,并将 Kafka 服务映射到主机的端口9092。还设置了一些环境变量来配置 Kafka,包括广告主机名,广告端口,Zookeeper 地址和要创建的主题。 4. 启动 Kafka 容器。在命令行中,导航到包含 `docker-compose.yml` 文件的目录,并运行以下命令来启动 Kafka 容器docker-compose up -d。 这将启动 Kafka 和 Zookeeper 容器,并将它们连接起来。您可以使用 `docker ps` 命令检查容器是否正在运行。 现在,您已经成功地使用 Docker Compose 安装Kafka。您可以使用 Kafka 客户端或其他工具来访问和操作 Kafka。 请记住,这只是一个简单的示例配置文件,您可以根据您的需求进行进一步的定制。另外,您还可以扩展配置文件以包含多个 Kafka brokers 和 Zookeeper 实例,以实现高可用性和容错性。 ### 回答3: 要在Docker安装Kafka,我们可以使用Docker Compose来简化配置和管理。Docker Compose是一个用于定义和管理多个容器的工具,通过一个YAML文件来描述服务的配置。 首先,我们需要创建一个docker-compose.yml文件来定义Kafka服务的配置。这个文件包含了以下几个关键部分: 1. 版本声明:指定Docker Compose的版本。 2. 服务定义:在services部分,我们定义了一个kafka服务。这个服务使用了wurstmeister/kafka镜像,并设置了一些环境变量来配置Kafka的参数,如Kafka的版本、端口号等。 3. 网络设置:在networks部分,我们定义了一个网络,以便Kafka和其他服务可以在同一个网络中进行通信。 接下来,我们可以使用以下命令来启动Kafka服务: ``` docker-compose up -d ``` 这将会根据docker-compose.yml文件中的配置启动Kafka服务,并在后台运行。 我们可以使用以下命令来检查Kafka服务是否成功启动: ``` docker-compose ps ``` 如果输出中显示了一个名为kafka的服务,并且状态为"Up",则说明Kafka已成功启动。 我们可以通过以下命令来停止并移除Kafka服务: ``` docker-compose down ``` 这将会停止并移除Kafka服务以及创建的容器和网络。 通过使用Docker Compose,我们可以轻松地在Docker上部署并管理Kafka服务,而无需手动配置和管理容器。这大大简化了安装使用Kafka的过程,提高了开发和部署的效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

沈自在-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值