go环境使用kafka简单示例

环境和工具:

kafka

golang

介绍:

要在 Go 中使用 Kafka,您可以使用 sarama 这样的第三方库。sarama 是 Kafka 的 Go 客户端,提供了与 Kafka 集群进行通信所需的功能。

1、安装 sarama 库
首先,您需要安装 sarama 库。您可以使用 go get 命令来安装:

go get github.com/Shopify/sarama

2、生产消息:
以下是一个简单的示例代码,用于在 Go 中生产消息:

package main

import (
	"log"
	"os"
	"os/signal"

	"github.com/Shopify/sarama"
)

func main() {
	config := sarama.NewConfig()
	config.Producer.RequiredAcks = sarama.WaitForAll
	config.Producer.Retry.Max = 5
	config.Producer.Return.Successes = true

	producer, err := sarama.NewSyncProducer([]string{"localhost:9092"}, config)
	if err != nil {
		log.Fatalf("Error creating producer: %v", err)
	}
	defer producer.Close()

	topic := "test-topic"
	message := &sarama.ProducerMessage{
		Topic: topic,
		Value: sarama.StringEncoder("Hello, Kafka!"),
	}

	_, _, err = producer.SendMessage(message)
	if err != nil {
		log.Fatalf("Failed to send message: %v", err)
	}

	log.Println("Message sent successfully")

	// Handle graceful shutdown
	signals := make(chan os.Signal, 1)
	signal.Notify(signals, os.Interrupt)
	<-signals
}

这个程序将连接到本地 Kafka 服务器(localhost:9092),向名为 test-topic 的主题发送一条消息。 

3、消费消息:
以下是一个简单的示例代码,用于在 Go 中消费消息:

package main

import (
	"log"
	"os"
	"os/signal"

	"github.com/Shopify/sarama"
)

func main() {
	config := sarama.NewConfig()
	config.Consumer.Return.Errors = true

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

	topic := "test-topic"
	partition := int32(0)

	partitionConsumer, err := consumer.ConsumePartition(topic, partition, sarama.OffsetNewest)
	if err != nil {
		log.Fatalf("Error creating partition consumer: %v", err)
	}
	defer partitionConsumer.Close()

	signals := make(chan os.Signal, 1)
	signal.Notify(signals, os.Interrupt)

	doneCh := make(chan struct{})
	go func() {
		for {
			select {
			case err := <-partitionConsumer.Errors():
				log.Printf("Consumer error: %v", err)
			case msg := <-partitionConsumer.Messages():
				log.Printf("Received message: %s", string(msg.Value))
			case <-signals:
				log.Println("Interrupt signal received, shutting down consumer...")
				close(doneCh)
				return
			}
		}
	}()

	<-doneCh
}

这个程序将连接到本地 Kafka 服务器(localhost:9092),消费名为 test-topic 的主题中的消息。

以上示例提供了 Go 中使用 Kafka 的基本功能。您可以根据实际需求进行调整和扩展。

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值