add properties to kafka client

This commit is contained in:
Francis Cao 2022-08-18 11:07:30 -07:00
parent 508e23c52e
commit 0beedb0e1c
2 changed files with 80 additions and 21 deletions

View File

@ -1,27 +1,84 @@
--- version: "3"
version: '3'
services: services:
zookeeper: zookeeper:
image: confluentinc/cp-zookeeper:7.0.1 image: 'bitnami/zookeeper:latest'
container_name: zookeeper
environment:
ZOOKEEPER_CLIENT_PORT: 2181
ZOOKEEPER_TICK_TIME: 2000
broker:
image: confluentinc/cp-kafka:7.0.1
container_name: broker
ports: ports:
# To learn about configuring Kafka for access across networks see - '2181:2181'
# https://www.confluent.io/blog/kafka-client-cannot-connect-to-broker-on-aws-on-docker-etc/ environment:
- "9092:9092" - ALLOW_ANONYMOUS_LOGIN=yes
kafka1:
image: 'bitnami/kafka:latest'
container_name: kafka1
ports:
- '9092:9092'
- '19092:19092'
environment:
- KAFKA_BROKER_ID=1
- KAFKA_CFG_ZOOKEEPER_CONNECT=zookeeper:2181
- ALLOW_PLAINTEXT_LISTENER=yes
- KAFKA_CFG_LISTENER_SECURITY_PROTOCOL_MAP=CLIENT:PLAINTEXT,EXTERNAL:PLAINTEXT
- KAFKA_CFG_LISTENERS=CLIENT://:19092,EXTERNAL://0.0.0.0:9092
- KAFKA_CFG_ADVERTISED_LISTENERS=CLIENT://kafka1:19092,EXTERNAL://dev-01.umami.dev:9092
- KAFKA_CFG_INTER_BROKER_LISTENER_NAME=CLIENT
depends_on: depends_on:
- zookeeper - zookeeper
kafka2:
image: 'bitnami/kafka:latest'
container_name: kafka2
ports:
- '9093:9093'
- '19093:19093'
environment: environment:
KAFKA_BROKER_ID: 1 - KAFKA_BROKER_ID=2
KAFKA_ZOOKEEPER_CONNECT: 'zookeeper:2181' - KAFKA_CFG_ZOOKEEPER_CONNECT=zookeeper:2181
KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: PLAINTEXT:PLAINTEXT,PLAINTEXT_INTERNAL:PLAINTEXT - ALLOW_PLAINTEXT_LISTENER=yes
KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://localhost:9092,PLAINTEXT_INTERNAL://broker:29092 - KAFKA_CFG_LISTENER_SECURITY_PROTOCOL_MAP=CLIENT:PLAINTEXT,EXTERNAL:PLAINTEXT
KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1 - KAFKA_CFG_LISTENERS=CLIENT://:19093,EXTERNAL://0.0.0.0:9093
KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 1 - KAFKA_CFG_ADVERTISED_LISTENERS=CLIENT://kafka2:19093,EXTERNAL://dev-01.umami.dev:9093
KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 1 - KAFKA_CFG_INTER_BROKER_LISTENER_NAME=CLIENT
depends_on:
- zookeeper
kafka3:
image: 'bitnami/kafka:latest'
container_name: kafka3
ports:
- '9094:9094'
- '19094:19094'
environment:
- KAFKA_BROKER_ID=3
- KAFKA_CFG_ZOOKEEPER_CONNECT=zookeeper:2181
- ALLOW_PLAINTEXT_LISTENER=yes
- KAFKA_CFG_LISTENER_SECURITY_PROTOCOL_MAP=CLIENT:PLAINTEXT,EXTERNAL:PLAINTEXT
- KAFKA_CFG_LISTENERS=CLIENT://:19094,EXTERNAL://0.0.0.0:9094
- KAFKA_CFG_ADVERTISED_LISTENERS=CLIENT://kafka3:19094,EXTERNAL://dev-01.umami.dev:9094
- KAFKA_CFG_INTER_BROKER_LISTENER_NAME=CLIENT
depends_on:
- zookeeper
# version: "3"
# services:
# zookeeper:
# image: 'bitnami/zookeeper:latest'
# ports:
# - '2181:2181'
# environment:
# - ALLOW_ANONYMOUS_LOGIN=yes
# kafka:
# image: 'bitnami/kafka:latest'
# ports:
# - '9092:9092'
# - '9093:9093'
# environment:
# - KAFKA_BROKER_ID=1
# - KAFKA_CFG_ZOOKEEPER_CONNECT=zookeeper:2181
# - ALLOW_PLAINTEXT_LISTENER=yes
# - KAFKA_CFG_LISTENER_SECURITY_PROTOCOL_MAP=CLIENT:PLAINTEXT,EXTERNAL:PLAINTEXT
# - KAFKA_CFG_LISTENERS=CLIENT://:9092,EXTERNAL://0.0.0.0:9093
# - KAFKA_CFG_ADVERTISED_LISTENERS=CLIENT://kafka:9092,EXTERNAL://dev-01.umami.dev:9093
# - KAFKA_CFG_INTER_BROKER_LISTENER_NAME=CLIENT
# depends_on:
# - zookeeper

View File

@ -13,11 +13,13 @@ export function getKafkaClient() {
return new Kafka({ return new Kafka({
clientId: 'umami', clientId: 'umami',
brokers: brokers, brokers: brokers,
connectionTimeout: 3000,
}); });
} else { } else {
return new Kafka({ return new Kafka({
clientId: 'umami', clientId: 'umami',
brokers: brokers, brokers: brokers,
connectionTimeout: 3000,
ssl: true, ssl: true,
sasl: { sasl: {
mechanism: 'plain', mechanism: 'plain',