前言
动手实践往往比看看更重要
单机版 Docker 搭建
version: '2'
services:
zookeeper:
image: wurstmeister/zookeeper
ports:
- "2181:2181"
kafka:
image: wurstmeister/kafka
depends_on: [ zookeeper ]
ports:
- "9092:9092"
environment:
KAFKA_ADVERTISED_HOST_NAME: kafka
KAFKA_ADVERTISED_PORT: 9092
KAFKA_CREATE_TOPICS: "test:1:1"
KAFKA_ZOOKEEPER_CONNECT: "zookeeper:2181"
注意事项:
- 如果想要 java 客户端能够正常连接上 kafka, 需要配置宿主机的 host
sudo vim /etc/hosts
172.20.10.6 kafka
- 如何使用 kafka 自带的 kafka-console-producer 测试发送消息?
kafka-console-producer.sh --bootstrap-server kafka:9092 --topic test
集群版 + kafka manager
kafka 集群 docker-compose
version: '2'
services:
zookeeper:
image: wurstmeister/zookeeper
ports:
- "2181:2181"
kafka1:
restart: always
image: wurstmeister/kafka
depends_on: [ zookeeper ]
ports:
- "9092:9092"
environment:
KAFKA_BROKER_ID: 1
KAFKA_ZOOKEEPER_CONNECT: "zookeeper:2181"
KAFKA_ADVERTISED_LISTENERS: "PLAINTEXT://kafka1:9092"
KAFKA_LISTENERS: "PLAINTEXT://kafka1:9092"
KAFKA_PORT: 9092
kafka2:
restart: always
image: wurstmeister/kafka
depends_on: [ zookeeper ]
ports:
- "9093:9093"
environment:
KAFKA_BROKER_ID: 2
KAFKA_ZOOKEEPER_CONNECT: "zookeeper:2181"
KAFKA_ADVERTISED_LISTENERS: "PLAINTEXT://kafka2:9093"
KAFKA_LISTENERS: "PLAINTEXT://kafka2:9093"
KAFKA_PORT: 9093
kafka3:
restart: always
image: wurstmeister/kafka
depends_on: [ zookeeper ]
ports:
- "9094:9094"
environment:
KAFKA_BROKER_ID: 3
KAFKA_ZOOKEEPER_CONNECT: "zookeeper:2181"
KAFKA_ADVERTISED_LISTENERS: "PLAINTEXT://kafka3:9094"
KAFKA_LISTENERS: "PLAINTEXT://kafka3:9094"
KAFKA_PORT: 9094
注意事项:
- 如果想要 java 客户端能够正常连接上 kafka, 需要配置宿主机的 host
sudo vim /etc/hosts
172.20.10.6 kafka1
172.20.10.6 kafka2
172.20.10.6 kafka3
- 如何使用 kafka 自带的 kafka-console-producer 测试发送消息?这里假设是进入到 kafka3 容器中
kafka-topics.sh --create --zookeeper zookeeper:2181 --replication-factor 3 --partitions 3 --topic test2
kafka-console-producer.sh --bootstrap-server kafka3:9094 --topic test
kafka-manager docker-compose
version: "2"
services:
kafka-manager:
image: kafkamanager/kafka-manager
container_name: kafka-manager
ports:
- "9000:9000"
external_links: # 连接本compose文件以外的container
- kafka_kafka1_1
- kafka_kafka2_1
- kafka_kafka3_1
environment:
ZK_HOSTS: kafka_zookeeper_1:2181
networks:
default:
external:
name: kafka_default
注意事项
kafka-manager、与 kafka 集群不在同一个 compose 中。因此这里需要使用 networks 连接到 kafka 集群的网络中
基本操作
以下均在 docker 内操作
cd /opt/kafka/bin
- 创建主题
创建了 1 个副本 1 个分区的主题
kafka-topics.sh --create --zookeeper zookeeper:2181 --replication-factor 1 --partitions 1 --topic test2
- 查看主题
kafka-topics.sh --zookeeper zookeeper:2181 --list
- 查看主题详情
kafka-topics.sh --zookeeper zookeeper:2181 --describe --topic test2
- 发送消息
kafka-console-producer.sh --bootstrap-server localhost:9092 --topic test2
- 消费消息
kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic test2 --from-beginning
springboot 连接 kafka
maven
org.springframework.boot
spring-boot-starter-parent
2.1.10.RELEASE
org.springframework.boot
spring-boot-starter-web
org.springframework.kafka
spring-kafka
yaml
server:
port: 9009
spring:
kafka:
bootstrap-servers: 127.0.0.1:9092,127.0.0.1:9093,127.0.0.1:9094
producer:
key-serializer: org.apache.kafka.common.serialization.StringSerializer
value-serializer: org.apache.kafka.common.serialization.StringSerializer
consumer:
key-serializer: org.apache.kafka.common.serialization.StringSerializer
value-serializer: org.apache.kafka.common.serialization.StringSerializer
group-id: goup1 # 消费组
生产者
@Autowired
private KafkaTemplate kafkaTemplate;
kafkaTemplate.send("test2","qweqwe");
消费者
@KafkaListener(topics = "test2")
public void onMsg(String msg) {
log.error("kafka {}" ,msg);
System.out.println(msg);
}