网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
二、使用介绍
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对象的创建,支持两种方式,我们采用第二种方式:
2.运行结果
总结
本节我们了解到了ClusterAdmin的对象和操作,获取到了topic更详细的信息。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**