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下载

相关推荐
smileNicky4 小时前
Kafka 为什么具有高吞吐量的特性?
分布式·kafka
不过普通话一乙不改名7 小时前
第四章:并发编程的基石与高级模式之Select语句与多路复用
开发语言·golang
Pure_Eyes9 小时前
go 常见面试题
开发语言·后端·golang
Hello.Reader11 小时前
Kafka 在 6 大典型用例的落地实践架构、参数与避坑清单
数据库·架构·kafka
wuxingge11 小时前
kafka常用命令
kafka
小猿姐13 小时前
KubeBlocks for Kafka 揭秘
kafka·kubernetes
{⌐■_■}13 小时前
【ElasticSearch】使用docker compose,通过编写yml安装es8.15和kibana可视化界面操作,go连接es
elasticsearch·docker·golang
Hello.Reader13 小时前
用一根“数据中枢神经”串起业务从事件流到 Apache Kafka
分布式·kafka·apache
Tony Bai2 天前
泛型重塑 Go 错误检查:errors.As 的下一站 AsA?
开发语言·后端·golang