linux环境下,使用docker安装apache kafka (docker-compose)

使用docker 创建kafka,达到项目中连接linux服务器创建的kafka,进行开发使用。 1.在linux中,在指定位置路径,创建docker-compose.yml文件,然后进行添加内容,我用的docker版本是26.1.1:

yaml 复制代码
version: '3'
services:
  zookeeper:
    image: confluentinc/cp-zookeeper:7.6.0
    hostname: zookeeper
    container_name: zookeeper
    ports:
      - "2181:2181"
    environment:
      ZOOKEEPER_CLIENT_PORT: 2181
      ZOOKEEPER_TICK_TIME: 2000

  kafka:
    image: confluentinc/cp-kafka:7.6.0
    hostname: kafka
    container_name: kafka
    depends_on:
      - zookeeper
    ports:
      - "9092:9092"
      - "29092:29092"
    environment:
      KAFKA_BROKER_ID: 1
      KAFKA_ZOOKEEPER_CONNECT: 'zookeeper:2181'
      KAFKA_LISTENERS: INTERNAL://0.0.0.0:29092,EXTERNAL://0.0.0.0:9092
      KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: INTERNAL:PLAINTEXT,EXTERNAL:PLAINTEXT
      KAFKA_ADVERTISED_LISTENERS: INTERNAL://kafka:29092,EXTERNAL://{服务器IP}:9092
      KAFKA_INTER_BROKER_LISTENER_NAME: INTERNAL
      KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
      KAFKA_GROUP_INITIAL_REBALANCE_DELAY_MS: 0
      KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 1
      KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 1

2.保存好docker-compose.yml

3.在docker-compose.yml文件目录下执行:docker-compose up -d

4.观察启动成功后,使用命令在linux服务器进行测试,

创建 topic (topic名字=test-topic)

docker exec kafka kafka-topics --create --topic test-topic --bootstrap-server localhost:9092 --partitions 1 --replication-factor 1

生产消息(交互式)

docker exec -it kafka kafka-console-producer --topic test-topic --bootstrap-server localhost:9092

-交互模式下输入kafka value,然后回车

消费消息(另开终端)

docker exec -it kafka kafka-console-consumer --topic test-topic --bootstrap-server localhost:9092 --from-beginning

-输入消费信息命令后,在控制台观察输出,在生产者回车value后,消费者控制台会同步出现value

5.springBoot项目中配置kafka,供参考:

yaml 复制代码
kafka:
  topic: kafka_topic_outputMessage

spring:
  kafka:
    bootstrap-servers: {kafka所在linux机器IP}:9092
    producer:
      key-serializer: org.apache.kafka.common.serialization.StringSerializer
      value-serializer: org.apache.kafka.common.serialization.StringSerializer
    consumer:
      properties:
        group:
          id: {消费者消费的组ID}
      key-deserializer: org.apache.kafka.common.serialization.StringDeserializer
      value-deserializer: org.apache.kafka.common.serialization.StringDeserializer
相关推荐
代码游侠几秒前
学习笔记——Linux内核与嵌入式开发1
linux·运维·前端·arm开发·单片机·嵌入式硬件·学习
微尘hjx9 分钟前
【Gstreamer 应用程序开发手册 01】关于GSTREAMER
linux·音视频·媒体
LaoWaiHang1 小时前
Linux基础知识13:用户、用户组管理
linux
only-qi2 小时前
微服务场景下,如何实现分布式事务来保证一致性?
分布式·微服务·架构
Coder个人博客2 小时前
Linux6.19-ARM64 mm init子模块深入分析
linux·安全·车载系统·系统架构·系统安全·鸿蒙系统·安全架构
济6172 小时前
ARM Linux 驱动开发篇----Linux驱动开发与裸机开发的区别---- Ubuntu20.04
linux·arm开发·驱动开发
慎思知行2 小时前
Discord中创建机器人的流程
linux·服务器·机器人
enbug2 小时前
编译安卓内核:以坚果R1、魔趣MK100(Android 10)系统为例
android·linux
玉梅小洋2 小时前
Linux命令详解 —— IP 命令及永久配置
linux·运维·tcp/ip
江畔何人初2 小时前
k8s中Role与networkpolicy区别
linux·运维·云原生