golang封装调用kafka的工具包

封装一个golang调用kafka的工具包,包含了consumer,producer,auth,在自己的生产环境上做过验证。可以做参考作用,也可以直接使用。

部分代码

go 复制代码
// Run 执行消费动作
func (cg *ConsumerGroup) Run(ctx context.Context) {
	defer cg.close()
	for {
		select {
		case err := <-cg.consumer.Errors():
			cg.logger.WithError(err).Errorln("Error channel")
			cg.handleConsumeError(err)
		case <-ctx.Done():
			err := ctx.Err()
			if err == nil || errors.Is(err, context.Canceled) || errors.Is(err, context.DeadlineExceeded) {
				// 正常退出
				return
			}
			cg.logger.WithError(err).Errorln("上下文异常退出")
		default:
			if err := cg.consumer.Consume(ctx, cg.options.topics, cg.options); err != nil {
				cg.logger.WithError(err).Errorln("Consume Error channel")
				cg.handleConsumeError(err)
			}
		}
	}
}
go 复制代码
func (kc *KafkaClient) CreateTopic(ctx context.Context, topicName string, ops ...TopicOption) (err error) {
	topicConf := &sarama.TopicDetail{
		NumPartitions:     3,
		ReplicationFactor: 1,
		ConfigEntries: map[string]*string{
			"cleanup.policy": &TopicTTLPolicy,
			"retention.ms":   &TopicTTLRetention,
		},
	}
	for _, op := range ops {
		op(topicConf)
	}
	return kc.cli.CreateTopic(topicName, topicConf, false)
}

代码太多,全部写出来不现实,详细代码在这个下载包里,有test文件可以查看是如何调用的

另外需要自己处理消费时的速度,比如用channel控制同时消费的数量
golang调用kafka下载

相关推荐
未来之窗软件服务6 小时前
幽冥大陆(三十五)S18酒店门锁SDK go语言——东方仙盟筑基期
java·前端·golang·智能门锁·仙盟创梦ide·东方仙盟·东方仙盟sdk
Sinowintop6 小时前
易连EDI-EasyLink无缝集成之消息队列Kafka
分布式·网络协议·kafka·集成·国产化·as2·国产edi
0***86336 小时前
【Golang】——Gin 框架中的表单处理与数据绑定
microsoft·golang·gin
C***11506 小时前
对基因列表中批量的基因进行GO和KEGG注释
开发语言·数据库·golang
u***42076 小时前
Golang 构建学习
开发语言·学习·golang
佛祖让我来巡山7 小时前
Kafka入门:从初识到Spring Boot实战
kafka·kafka入门·kafka案例
CryptoPP8 小时前
使用 KLineChart 这个轻量级的前端图表库
服务器·开发语言·前端·windows·后端·golang
qq_172805598 小时前
Go 语言结构型设计模式深度解析
开发语言·设计模式·golang
二进制_博客9 小时前
eventTime+watermarker+allowedLateness到底窗口关闭时间是什么?
flink·kafka
雨中散步撒哈拉11 小时前
17、做中学 | 初三下期 Golang文件操作
开发语言·后端·golang