首页 > 编程语言 > 详细

Spring Boot 中使用kafka AdminClient管理Kafka

时间:2021-03-27 22:29:16      阅读:188      评论:0      收藏:0      [点我收藏+]

2021-03-27

import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Map;
import java.util.concurrent.ExecutionException;

import org.apache.kafka.clients.admin.AdminClient;
import org.apache.kafka.clients.admin.Config;
import org.apache.kafka.clients.admin.ConfigEntry;
import org.apache.kafka.clients.admin.CreateTopicsResult;
import org.apache.kafka.clients.admin.DescribeClusterOptions;
import org.apache.kafka.clients.admin.DescribeClusterResult;
import org.apache.kafka.clients.admin.DescribeConfigsResult;
import org.apache.kafka.clients.admin.ListTopicsResult;
import org.apache.kafka.clients.admin.NewTopic;
import org.apache.kafka.clients.admin.TopicListing;
import org.apache.kafka.common.Node;
import org.apache.kafka.common.config.ConfigResource;
import org.junit.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.kafka.core.KafkaAdmin;

import com.ibm.dsw.quote.preentitlement.base.AbstractBaseTest;

public class AdminClientTest extends AbstractBaseTest {

    @Autowired
    private KafkaAdmin admin;

    @Test
    public void listTopic() throws InterruptedException, ExecutionException {
        AdminClient client = AdminClient.create(admin.getConfig());

        // create topic
        NewTopic newTopic = new NewTopic("test1", 3, (short) 1);
        Collection<NewTopic> newTopicList = new ArrayList<>();
        newTopicList.add(newTopic);
        CreateTopicsResult createTopicResult = client.createTopics(newTopicList);
        createTopicResult.all().get();
        
        // list topic
        ListTopicsResult result = client.listTopics();
        Collection<TopicListing> topic = result.listings().get();
        topic.forEach(each -> System.out.println(each.name()));

        
        //get topic configuration
        DescribeConfigsResult ret = client.describeConfigs(Collections.singleton(new ConfigResource(ConfigResource.Type.TOPIC, "TopicName")));
        Map<ConfigResource, Config> configs = ret.all().get();
        for (Map.Entry<ConfigResource, Config> entry : configs.entrySet()) {
             ConfigResource key = entry.getKey();
             Config value = entry.getValue();
             System.out.println(String.format("Resource type: %s, resource name: %s", key.type(), key.name()));
             Collection<ConfigEntry> configEntries = value.entries();
             for (ConfigEntry each : configEntries) {
                  System.out.println(each.name() + " = " + each.value());
             }
         }

        //get cluster information
        DescribeClusterResult ret2= client.describeCluster(new DescribeClusterOptions());
        String clusterId = ret2.clusterId().get();
        System.out.println("----------------clusterId------------"+clusterId);
        Collection<Node> nodes = ret2.nodes().get();
        for (Node node: nodes) {
            System.out.println(node.host());
        }
        
           
        client.close();

    }

}

 

Spring Boot 中使用kafka AdminClient管理Kafka

原文:https://www.cnblogs.com/Ivyduan/p/14586400.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!