搭建kafka测试环境

搭建kafka测试环境

启动zookeeper

docker pull bitnami/zookeeper
docker run -d --name zookeeper \
    -e ALLOW_ANONYMOUS_LOGIN=yes \
    bitnami/zookeeper:latest

启动kafka

创建网络与连接

docker network create kafka-network
docker network connect kafka-network zookeeper
docker network connect kafka-network kafka

安装kafka

docker pull bitnami/kafka

启动kafka

docker run -d --name kafka --network kafka-network \
    -e KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181 \
    -e KAFKA_LISTENERS=PLAINTEXT://:9092 \
    -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://kafka:9092 \
    -e KAFKA_HEAP_OPTS="-Xmx512M -Xms512M" \
    -p 9092:9092 bitnami/kafka

在这个命令中,KAFKA_HEAP_OPTS 环境变量用于限制 Kafka 使用的 JVM 堆内存大小。

使用Docker Compose 启动(推荐)

使用 Docker Compose 的优点之一就是它管理了网络和服务之间的依赖关系,使得整个过程更加简洁和自动化。

创建一个Docker Compose 文件,名称为 docker-compose-kafka-dev.yml

version: '3'

services:
  zookeeper:
    image: bitnami/zookeeper:latest
    environment:
      - ALLOW_ANONYMOUS_LOGIN=yes
    networks:
      - kafka-network

  kafka:
    image: bitnami/kafka:latest
    environment:
      - KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181
      - KAFKA_LISTENERS=PLAINTEXT://:9092
      - KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://localhost:9092
      - KAFKA_HEAP_OPTS=-Xmx512M -Xms512M
    ports:
      - "9092:9092"
    depends_on:
      - zookeeper
    networks:
      - kafka-network

networks:
  kafka-network:
    driver: bridge

启动容器

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

创建topic

进入容器

docker exec -it [KAFKA_CONTAINER_NAME] /bin/bash

KAFKA_CONTAINER_NAME 可使用 docker ps 查看

创建topic

kafka-topics.sh --create --topic your-topic-name --bootstrap-server localhost:9092 --partitions 1 --replication-factor 1

查看topic

kafka-topics.sh --list --bootstrap-server localhost:9092

代码示例

生产者
/provider/main.go

package main

import (
	"fmt"
	"log"
	"net/http"

	"github.com/Shopify/sarama"
)

var producer sarama.SyncProducer

func main() {
   
	var err error
	producer, err = sarama.NewSyncProducer([]string{
   "localhost:9092"}, nil)
	if err != nil {
   
		log.Fatalf("Error creating Kafka producer: %s", err)
	}
	defer producer.Close()

	http.HandleFunc("/send", sendMessage)
	log.Fatal(http.ListenAndServe(":8080", nil))
}

func sendMessage(w http.ResponseWriter, r *http.Request) {
   
	message := r.URL.Query().Get("message")
	if message == "" {
   
		http.Error(w, "Missing message", http.StatusBadRequest)
		return
	}

	_, _, err := producer.SendMessage(&sarama.ProducerMessage{
   
		Topic: "your-topic-name",
		Value: sarama.StringEncoder(message),
	})
	if err != nil {
   
		http.Error(w, err.Error(), http.StatusInternalServerError)
		return
	}

	fmt.Fprintf(w, "Message sent: %s", message)
}

消费者
/consumer/main.go

package main

import (
	"fmt"
	"log"

	"github.com/Shopify/sarama"
)

func main() {
   
	consumer, err := sarama.NewConsumer([]string{
   "localhost:9092"}, nil)
	if err != nil {
   
		log.Fatalf("Error creating Kafka consumer: %s", err)
	}
	defer consumer.Close()

	partitionConsumer, err := consumer.ConsumePartition("your-topic-name", 0, sarama.OffsetNewest)
	if err != nil {
   
		log.Fatalf("Error creating Kafka partition consumer: %s", err)
	}
	defer partitionConsumer.Close()

	for message := range partitionConsumer.Messages() {
   
		fmt.Printf("Received message: %s\n", string(message.Value))
	}
}

测试请求

curl localhost:8080/send?message=hello

终端返回: Message sent: hello

消费者控制台输出: Received message: hello

相关推荐

  1. kafka测试环境

    2024-02-06 06:08:03       27 阅读
  2. KAFKA环境

    2024-02-06 06:08:03       38 阅读
  3. ArchLinuxriscv测试环境(失败)

    2024-02-06 06:08:03       41 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-06 06:08:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-06 06:08:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-06 06:08:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-06 06:08:03       18 阅读

热门阅读

  1. 软件漏洞概念与原理

    2024-02-06 06:08:03       27 阅读
  2. C语言冒泡排序介绍

    2024-02-06 06:08:03       29 阅读
  3. Matlab建立TCP/IP链接

    2024-02-06 06:08:03       32 阅读
  4. C语言-4

    C语言-4

    2024-02-06 06:08:03      27 阅读
  5. Days 22 ElfBoard 基于QT的智慧家庭控制中心

    2024-02-06 06:08:03       24 阅读
  6. 服务器托管有哪些好处?

    2024-02-06 06:08:03       26 阅读
  7. SpringBoot过滤器获取请求的参数

    2024-02-06 06:08:03       31 阅读
  8. Centos 7系统安装proftpd-1.3.8过程

    2024-02-06 06:08:03       26 阅读
  9. 【无标题】

    2024-02-06 06:08:03       28 阅读
  10. 关闭Ubuntu 默认开启的自动安全更新

    2024-02-06 06:08:03       24 阅读
  11. GPT-4是什么?如何使用GPT-4?

    2024-02-06 06:08:03       28 阅读