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

相关推荐
Hsu_kk4 分钟前
Kafka 安装教程
大数据·分布式·kafka
苍老流年5 分钟前
1. kafka分布式环境搭建
分布式·kafka
sj11637394036 分钟前
Kafka参数了解
数据库·分布式·kafka
Hsu_kk8 分钟前
Kafka Eagle 安装教程
分布式·kafka
CodingBrother12 分钟前
Kafka 与 RabbitMQ 的联系
分布式·kafka·rabbitmq
@东辰13 分钟前
【golang-技巧】-自定义k8s-operator-by kubebuilder
开发语言·golang·kubernetes
@东辰1 小时前
【golang-技巧】- 定时任务 - cron
开发语言·golang·cron
jerry6098 小时前
7天用Go从零实现分布式缓存GeeCache(改进)(未完待续)
分布式·缓存·golang
杜杜的man8 小时前
【go从零单排】Closing Channels通道关闭、Range over Channels
开发语言·后端·golang
大熊程序猿11 小时前
ubuntu 安装kafka-eagle
linux·ubuntu·kafka