既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
前言
上一节,我们已经简单接触了sarama包的使用,通过Client类型操作,获取了kafka的元数据信息,如果我们需要获取kafka,topic详情信息呢,下面我们使用ClusterAdmin类的使用
ClusterAdmin是Kafka的管理客户端,支持管理和检查主题、代理、配置和ACL。所需的最低代理版本为0.10.0.0。具有更严格要求的方法将指定所需的最低代理版本。您必须在客户端上调用Close()以避免泄漏
二、使用介绍
1.直接上代码
代码如下(示例):
package main
import (
"fmt"
"log"
"github.com/IBM/sarama"
)
func main() {
brokers := []string{"IP1:Port1", "IP2:Port2", "IP3:Port3"}
client, err := sarama.NewClient(brokers, nil)
if err != nil {
log.Fatal("Failed to create client", err)
}
admin, err := sarama.NewClusterAdminFromClient(client)
if err != nil {
log.Fatal("Failed to create cluster admin from client", err)
}
defer admin.Close()
// 列举所有的Topic详情
// List the topics available in the cluster with the default options.
// ListTopics()(map[string]TopicDetail, error)
topics, err := admin.ListTopics()
if err != nil {
log.Fatal("Failed to list topics", err)
}
for topicName, topicDetail := range topics {
fmt.Printf("%v : %v \n", topicName, topicDetail)
fmt.Printf("%v : 分区数:%v 副本数:%v 副本分布: %v \n", topicName, topicDetail.NumPartitions, topicDetail.ReplicationFactor, topicDetail.ReplicaAssignment)
fmt.Printf("%v : %v \n", topicName, topicDetail.ConfigEntries)
for k, v := range topicDetail.ConfigEntries {
fmt.Printf("%v : %v \n", k, \*v)
}
}
}
说明:ClusterAdmin对象的创建,支持两种方式,我们采用第二种方式:
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**