Golang操作Kafka的实现示例
作者:YUHAOHAO 时间:2024-05-22 10:18:48
一.使用库说明
Golang中连接kafka可以使用第三方库:github.com/Shopify/sarama
二.Kafka Producer发送消息
package main
import (
"fmt"
"github.com/Shopify/sarama"
)
func main() {
config := sarama.NewConfig()
config.Producer.RequiredAcks = sarama.WaitForAll // 发送完数据需要leader和follower都确认
config.Producer.Partitioner = sarama.NewRandomPartitioner //写到随机分区中,我们默认设置32个分区
config.Producer.Return.Successes = true // 成功交付的消息将在success channel返回
// 构造一个消息
msg := &sarama.ProducerMessage{}
msg.Topic = "task"
msg.Value = sarama.StringEncoder("producer kafka messages...")
// 连接kafka
client, err := sarama.NewSyncProducer([]string{"192.20.216.8:9092"}, config)
if err != nil {
fmt.Println("Producer closed, err:", err)
return
}
defer client.Close()
// 发送消息
pid, offset, err := client.SendMessage(msg)
if err != nil {
fmt.Println("send msg failed, err:", err)
return
}
fmt.Printf("pid:%v offset:%v\n", pid, offset)
}
三.Kafka Consumer消费消息
package main
import (
"fmt"
"github.com/Shopify/sarama"
"sync"
)
func main() {
var wg sync.WaitGroup
consumer, err := sarama.NewConsumer([]string{"192.20.216.8:9092"}, nil)
if err != nil {
fmt.Println("Failed to start consumer: %s", err)
return
}
partitionList, err := consumer.Partitions("task-status-data") // 通过topic获取到所有的分区
if err != nil {
fmt.Println("Failed to get the list of partition: ", err)
return
}
fmt.Println(partitionList)
for partition := range partitionList{ // 遍历所有的分区
pc, err := consumer.ConsumePartition("task", int32(partition), sarama.OffsetNewest) // 针对每个分区创建一个分区消费者
if err != nil {
fmt.Println("Failed to start consumer for partition %d: %s\n", partition, err)
}
wg.Add(1)
go func(sarama.PartitionConsumer) { // 为每个分区开一个go协程取值
for msg := range pc.Messages() { // 阻塞直到有值发送过来,然后再继续等待
fmt.Printf("Partition:%d, Offset:%d, key:%s, value:%s\n", msg.Partition, msg.Offset, string(msg.Key), string(msg.Value))
}
defer pc.AsyncClose()
wg.Done()
}(pc)
}
wg.Wait()
consumer.Close()
}
来源:https://www.cnblogs.com/yuhaohao/p/15439034.html
标签:Golang,操作,Kafka
0
投稿
猜你喜欢
Python 学习教程之networkx
2023-10-11 01:49:07
Python Pygame实战之飞机大战的实现
2023-10-19 17:30:30
Python+OpenCV实现单个圆形孔和针检测
2023-05-04 10:38:11
在VScode里面添加Python解释器的详细步骤
2021-12-04 16:03:11
解决Element中el-date-picker组件不回填的情况
2024-04-09 11:00:47
javascript面向对象编程(二)
2008-03-07 12:59:00
linux下导入、导出mysql数据库命令的实现方法
2024-01-23 15:55:33
简单了解python装饰器原理及使用方法
2023-11-02 11:55:02
pandas通过索引进行排序的示例
2021-04-21 04:19:55
python __init__与 __new__的区别
2022-05-04 01:27:57
在python中实现将一张图片剪切成四份的方法
2023-10-04 02:20:04
python3 tkinter实现添加图片和文本
2022-08-07 04:28:17
关于django python manage.py startapp 应用名出错异常原因解析
2023-04-04 08:57:28
Python八皇后问题解答过程详解
2021-09-09 18:06:17
简单说明Python中的装饰器的用法
2022-01-30 21:57:32
Mysql中的触发器定义与使用
2024-01-26 10:37:45
实现php删除链表中重复的结点
2023-09-05 09:36:15
python数据分析基础知识之shape()函数的使用教程
2023-06-11 04:03:56
利用python实现逐步回归
2023-10-05 19:24:27
golang bufio包中Write方法的深入讲解
2024-05-08 10:45:31