Link Search Menu Expand Document

==zookeeper 하나 docker 다중 compose example==

version: ‘3’

services: zoo1: image: zookeeper:3.4.9 hostname: zoo1 ports:

  • “2181:2181” environment: ZOO_MY_ID: 1 ZOO_PORT: 2181 ZOO_SERVERS: server.1=zoo1:2888:3888 volumes:
  • ./zk-single-kafka-multiple/zoo1/data:/data
  • ./zk-single-kafka-multiple/zoo1/datalog:/datalog

kafka1: image: confluentinc/cp-kafka:5.5.0 hostname: kafka1 ports:

  • “9092:9092” environment: KAFKA_ADVERTISED_LISTENERS: LISTENER_DOCKER_INTERNAL://kafka1:19092, LISTENER_DOCKER_EXTERNAL://${DOCKER_HOST_IP:-127.0.0.1}:9092 KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: LISTENER_DOCKER_INTERNAL:PLAINTEXT,LISTENER_DOCKER_EXTERNAL:PLAINTEXT KAFKA_INTER_BROKER_LISTENER_NAME: LISTENER_DOCKER_INTERNAL KAFKA_ZOOKEEPER_CONNECT: “zoo1:2181” KAFKA_BROKER_ID: 1 KAFKA_LOG4J_LOGGERS: “kafka.controller=INFO,kafka.producer.async.DefaultEventHandler=INFO,state.change.logger=INFO” KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 2 KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 2 KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 2 volumes:
  • ./zk-single-kafka-multiple/kafka1/data:/var/lib/kafka/data depends_on:
  • zoo1 kafka2: image: confluentinc/cp-kafka:5.5.0 hostname: kafka2 ports:
  • “9093:9093” environment: KAFKA_ADVERTISED_LISTENERS: LISTENER_DOCKER_INTERNAL://kafka2:19093,LISTENER_DOCKER_EXTERNAL://${DOCKER_HOST_IP:-127.0.0.1}:9093 KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: LISTENER_DOCKER_INTERNAL:PLAINTEXT,LISTENER_DOCKER_EXTERNAL:PLAINTEXT KAFKA_INTER_BROKER_LISTENER_NAME: LISTENER_DOCKER_INTERNAL KAFKA_ZOOKEEPER_CONNECT: “zoo1:2181” KAFKA_BROKER_ID: 2 KAFKA_LOG4J_LOGGERS: “kafka.controller=INFO,kafka.producer.async.DefaultEventHandler=INFO,state.change.logger=INFO” KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 2 KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 2 KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 2 volumes:
  • ./zk-single-kafka-multiple/kafka2/data:/var/lib/kafka/data depends_on:
  • zoo1

kafka-schema-registry: image: confluentinc/cp-schema-registry:5.5.0 hostname: kafka-schema-registry

ports:

- “8081:8081”

environment:
  SCHEMA_REGISTRY_KAFKASTORE_BOOTSTRAP_SERVERS: PLAINTEXT://kafka1:19092
  SCHEMA_REGISTRY_HOST_NAME: kafka-schema-registry
  SCHEMA_REGISTRY_LISTENERS: http://0.0.0.0:8081
depends_on:
  - zoo1
  - kafka1
  - kafka2

kafka-rest-proxy: image: confluentinc/cp-kafka-rest:5.5.0 hostname: kafka-rest-proxy

ports:

- “8082:8082”

environment:
  # KAFKA_REST_ZOOKEEPER_CONNECT: zoo1:2181
  KAFKA_REST_LISTENERS: http://0.0.0.0:8082/
  KAFKA_REST_SCHEMA_REGISTRY_URL: http://kafka-schema-registry:8081/
  KAFKA_REST_HOST_NAME: kafka-rest-proxy
  KAFKA_REST_BOOTSTRAP_SERVERS: PLAINTEXT://kafka1:19092,PLAINTEXT://kafka2:19093
depends_on:
  - zoo1
  - kafka1
  - kafka2
  - kafka-schema-registry

kafka-topics-ui: image: landoop/kafka-topics-ui:0.9.4 hostname: kafka-topics-ui ports:

  • “9000:8000” environment: KAFKA_REST_PROXY_URL: “http://kafka-rest-proxy:8082/” PROXY: “true” depends_on:
  • zoo1
  • kafka1
  • kafka2
  • kafka-rest-proxy
  • kafka-schema-registry

</source>

==zookeeper 다중 docker 다중 compose example==

version: ‘2.1’

주키퍼와 카프카 서비스를 설정한다

services:

3개의 노드로 된 주키퍼 클러스터를 구성한다.

zoo1: image: zookeeper:3.4.9 hostname: zoo1

클라이언트 포트 2181를 bind 한다.

ports:

  • “2181:2181”

    주키퍼는 서버는 2개의 포트를 가진다.

    2888은 서버 노드끼리 통신을 하기 위해서 사용한다.

    3888은 리더 선출을 위해서 사용한다.

    environment: ZOO_MY_ID: 1 ZOO_PORT: 2181 ZOO_SERVERS: server.1=zoo1:2888:3888 server.2=zoo2:2888:3888 server.3=zoo3:2888:3888 volumes:

  • ./zk-multiple-kafka-multiple/zoo1/data:/data
  • ./zk-multiple-kafka-multiple/zoo1/datalog:/datalog

zoo2: image: zookeeper:3.4.9 hostname: zoo2 ports:

  • “2182:2182” environment: ZOO_MY_ID: 2 ZOO_PORT: 2182 ZOO_SERVERS: server.1=zoo1:2888:3888 server.2=zoo2:2888:3888 server.3=zoo3:2888:3888 volumes:
  • ./zk-multiple-kafka-multiple/zoo2/data:/data
  • ./zk-multiple-kafka-multiple/zoo2/datalog:/datalog

zoo3: image: zookeeper:3.4.9 hostname: zoo3 ports:

  • “2183:2183” environment: ZOO_MY_ID: 3 ZOO_PORT: 2183 ZOO_SERVERS: server.1=zoo1:2888:3888 server.2=zoo2:2888:3888 server.3=zoo3:2888:3888 volumes:
  • ./zk-multiple-kafka-multiple/zoo3/data:/data
  • ./zk-multiple-kafka-multiple/zoo3/datalog:/datalog

3개의 카프카 브로커를 구성한다.

Advertised listeners와 주키퍼 노드 포트를 등록한다.

4개의 파티션을 구성한다.

kafka1: image: confluentinc/cp-kafka:5.2.1 hostname: kafka1 ports:

  • “9092:9092” environment: KAFKA_ADVERTISED_LISTENERS: LISTENER_DOCKER_INTERNAL://kafka1:19092,LISTENER_DOCKER_EXTERNAL://${DOCKER_HOST_IP:-127.0.0.1}:9092 KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: LISTENER_DOCKER_INTERNAL:PLAINTEXT,LISTENER_DOCKER_EXTERNAL:PLAINTEXT KAFKA_INTER_BROKER_LISTENER_NAME: LISTENER_DOCKER_INTERNAL KAFKA_ZOOKEEPER_CONNECT: “zoo1:2181,zoo2:2182,zoo3:2183” KAFKA_BROKER_ID: 1 KAFKA_LOG4J_LOGGERS: “kafka.controller=INFO,kafka.producer.async.DefaultEventHandler=INFO,state.change.logger=INFO” volumes:
  • ./zk-multiple-kafka-multiple/kafka1/data:/var/lib/kafka/data depends_on:
  • zoo1
  • zoo2
  • zoo3

kafka2: image: confluentinc/cp-kafka:5.2.1 hostname: kafka2 ports:

  • “9093:9093” environment: KAFKA_ADVERTISED_LISTENERS: LISTENER_DOCKER_INTERNAL://kafka2:19093,LISTENER_DOCKER_EXTERNAL://${DOCKER_HOST_IP:-127.0.0.1}:9093 KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: LISTENER_DOCKER_INTERNAL:PLAINTEXT,LISTENER_DOCKER_EXTERNAL:PLAINTEXT KAFKA_INTER_BROKER_LISTENER_NAME: LISTENER_DOCKER_INTERNAL KAFKA_ZOOKEEPER_CONNECT: “zoo1:2181,zoo2:2182,zoo3:2183” KAFKA_BROKER_ID: 2 KAFKA_LOG4J_LOGGERS: “kafka.controller=INFO,kafka.producer.async.DefaultEventHandler=INFO,state.change.logger=INFO” volumes:
  • ./zk-multiple-kafka-multiple/kafka2/data:/var/lib/kafka/data depends_on:
  • zoo1
  • zoo2
  • zoo3

kafka3: image: confluentinc/cp-kafka:5.2.1 hostname: kafka3 ports:

  • “9094:9094” environment: KAFKA_ADVERTISED_LISTENERS: LISTENER_DOCKER_INTERNAL://kafka3:19094,LISTENER_DOCKER_EXTERNAL://${DOCKER_HOST_IP:-127.0.0.1}:9094 KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: LISTENER_DOCKER_INTERNAL:PLAINTEXT,LISTENER_DOCKER_EXTERNAL:PLAINTEXT KAFKA_INTER_BROKER_LISTENER_NAME: LISTENER_DOCKER_INTERNAL KAFKA_ZOOKEEPER_CONNECT: “zoo1:2181,zoo2:2182,zoo3:2183” KAFKA_BROKER_ID: 3 KAFKA_NUM_PARTITIONS: 4 KAFKA_LOG4J_LOGGERS: “kafka.controller=INFO,kafka.producer.async.DefaultEventHandler=INFO,state.change.logger=INFO” volumes:
  • ./zk-multiple-kafka-multiple/kafka3/data:/var/lib/kafka/data depends_on:
  • zoo1
  • zoo2
  • zoo3

kafka-schema-registry: image: confluentinc/cp-schema-registry:5.2.1 hostname: kafka-schema-registry ports:

  • “8081:8081” environment: SCHEMA_REGISTRY_KAFKASTORE_BOOTSTRAP_SERVERS: PLAINTEXT://kafka1:19092 SCHEMA_REGISTRY_HOST_NAME: kafka-schema-registry SCHEMA_REGISTRY_LISTENERS: http://0.0.0.0:8081 depends_on:
  • zoo1
  • zoo2
  • zoo3
  • kafka1
  • kafka2
  • kafka3

schema-registry-ui: image: landoop/schema-registry-ui:0.9.4 hostname: kafka-schema-registry-ui ports:

  • “8001:8000” environment: SCHEMAREGISTRY_URL: http://kafka-schema-registry:8081/ PROXY: “true” depends_on:
  • kafka-schema-registry

kafka-rest-proxy: image: confluentinc/cp-kafka-rest:5.2.1 hostname: kafka-rest-proxy ports:

  • “8082:8082” environment:

    KAFKA_REST_ZOOKEEPER_CONNECT: zoo1:2181

    KAFKA_REST_LISTENERS: http://0.0.0.0:8082/ KAFKA_REST_SCHEMA_REGISTRY_URL: http://kafka-schema-registry:8081/ KAFKA_REST_HOST_NAME: kafka-rest-proxy KAFKA_REST_BOOTSTRAP_SERVERS: PLAINTEXT://kafka1:19092 depends_on:

  • zoo1
  • zoo2
  • zoo3
  • kafka1
  • kafka2
  • kafka3
  • kafka-schema-registry

kafka-topics-ui: image: landoop/kafka-topics-ui:0.9.4 hostname: kafka-topics-ui ports:

  • “8000:8000” environment: KAFKA_REST_PROXY_URL: “http://kafka-rest-proxy:8082/” PROXY: “true” depends_on:
  • zoo1
  • zoo2
  • zoo3
  • kafka1
  • kafka2
  • kafka3
  • kafka-schema-registry
  • kafka-rest-proxy

kafka-connect: image: confluentinc/cp-kafka-connect:5.2.1 hostname: kafka-connect ports:

  • kafka-schema-registry
  • kafka-rest-proxy

kafka-connect: image: confluentinc/cp-kafka-connect:5.2.1 hostname: kafka-connect ports:

  • kafka-schema-registry
  • kafka-rest-proxy

kafka-connect: image: confluentinc/cp-kafka-connect:5.2.1 hostname: kafka-connect ports:

  • “8083:8083” environment: CONNECT_BOOTSTRAP_SERVERS: “kafka1:19092” CONNECT_REST_PORT: 8083 CONNECT_GROUP_ID: compose-connect-group CONNECT_CONFIG_STORAGE_TOPIC: docker-connect-configs CONNECT_OFFSET_STORAGE_TOPIC: docker-connect-offsets CONNECT_STATUS_STORAGE_TOPIC: docker-connect-status CONNECT_KEY_CONVERTER: io.confluent.connect.avro.AvroConverter CONNECT_KEY_CONVERTER_SCHEMA_REGISTRY_URL: ‘http://kafka-schema-registry:8081’ CONNECT_VALUE_CONVERTER: io.confluent.connect.avro.AvroConverter CONNECT_VALUE_CONVERTER_SCHEMA_REGISTRY_URL: ‘http://kafka-schema-registry:8081’ CONNECT_INTERNAL_KEY_CONVERTER: “org.apache.kafka.connect.json.JsonConverter” CONNECT_INTERNAL_VALUE_CONVERTER: “org.apache.kafka.connect.json.JsonConverter” CONNECT_REST_ADVERTISED_HOST_NAME: “kafka-connect” CONNECT_LOG4J_ROOT_LOGLEVEL: “INFO” CONNECT_LOG4J_LOGGERS: “org.apache.kafka.connect.runtime.rest=WARN,org.reflections=ERROR” CONNECT_CONFIG_STORAGE_REPLICATION_FACTOR: “1” CONNECT_OFFSET_STORAGE_REPLICATION_FACTOR: “1” CONNECT_STATUS_STORAGE_REPLICATION_FACTOR: “1” CONNECT_PLUGIN_PATH: ‘/usr/share/java,/etc/kafka-connect/jars’ volumes:
  • ./connectors:/etc/kafka-connect/jars/ depends_on:
  • zoo1
  • zoo2
  • zoo3
  • kafka1
  • kafka2
  • kafka3
  • kafka-schema-registry
  • kafka-rest-proxy

kafka-connect-ui: image: landoop/kafka-connect-ui:0.9.4 hostname: kafka-connect-ui ports:

  • “8003:8000” environment: CONNECT_URL: “http://kafka-connect:8083/” PROXY: “true” depends_on:
  • kafka-connect

ksql-server: image: confluentinc/cp-ksql-server:5.2.1 hostname: ksql-server ports:

  • “8088:8088” environment: KSQL_BOOTSTRAP_SERVERS: PLAINTEXT://kafka1:19092 KSQL_LISTENERS: http://0.0.0.0:8088/ KSQL_KSQL_SERVICE_ID: ksql-server_ depends_on:
  • zoo1
  • zoo2
  • zoo3
  • kafka1
  • kafka2
  • kafka3

zoonavigator-web: image: elkozmon/zoonavigator-web:0.5.1 ports:

  • “8004:8000” environment: API_HOST: “zoonavigator-api” API_PORT: 9000 links:
  • zoonavigator-api depends_on:
  • zoonavigator-api

zoonavigator-api: image: elkozmon/zoonavigator-api:0.5.1 environment: SERVER_HTTP_PORT: 9000 depends_on:

  • zoo1
  • zoo2
  • zoo3

</source>

==테스트==

  • kafkacat -b localhost:9092,localhost:9093 -L -t foobar -P
  • kafkacat -b localhost:9092,localhost:9093 -L -t foobar -C

==kafka group offset확인== kafka-consumer-groups –bootstrap-server localhost:9092 –group logstash –describe [[File:kafka-consumer-groups01.png|800px]]

==kafka group offset reset== kafka-consumer-groups –bootstrap-server localhost:9092 –group logstash –topic youtube-world-log-filebeat –reset-offsets –to-earliest –execute

==참고링크==

  • https://akageun.github.io/2019/09/10/docker-compose-local-kafka.html kafka zookeeper 설치
  • https://www.joinc.co.kr/w/man/12/Kafka/docker kafka cluster 설치