Creating a topic for Apache Kafka 0.9 Using Java

后端 未结 3 456
情话喂你
情话喂你 2021-01-13 13:59

I am programming a client to work with kafka 0.9. I want to know how to create a topic. This answer: How to create a Topic in Kafka through Java is similar to what I am aski

相关标签:
3条回答
  • 2021-01-13 14:29

    For Kafka 0.9 and above you need to use new API AdminZkClient. AdminUtils API is getting deprecated.

    String zookeeperHost = "127.0.0.1:2181";
    Boolean isSucre = false;
    int sessionTimeoutMs = 200000;
    int connectionTimeoutMs = 15000;
    int maxInFlightRequests = 10;
    Time time = Time.SYSTEM;
    String metricGroup = "myGroup";
    String metricType = "myType";
    KafkaZkClient zkClient = KafkaZkClient.apply(zookeeperHost,isSucre,sessionTimeoutMs,
                    connectionTimeoutMs,maxInFlightRequests,time,metricGroup,metricType);
    
    AdminZkClient adminZkClient = new AdminZkClient(zkClient);
    
    String topicName1 = "myTopic";
    int partitions = 3;
    int replication = 1;
    Properties topicConfig = new Properties();
    
    adminZkClient.createTopic(topicName1,partitions,replication,
                topicConfig,RackAwareMode.Disabled$.MODULE$);
    

    You can check more details at this link

    0 讨论(0)
  • 2021-01-13 14:34

    I tried following Soon Chee Loong's answer with Kafka 0.9.0.1 but had to make one change. ZKStringSerializer is now private. To create ZkUtils I used the following API (it creates a ZkClient internally):

    ZkUtils.apply(
        "zookeeper1:port1,zookeeper2:port2",
        sessionTimeoutMs,
        connectionTimeoutMs,
        false)
    
    0 讨论(0)
  • 2021-01-13 14:48

    After looking through the scala api and various links online.

    This is the solution I found:

    Maven Dependencies:

    <dependency>
        <groupId>org.apache.kafka</groupId>
        <artifactId>kafka_2.11</artifactId>
        <version>0.9.0.0</version>
    </dependency>
    <dependency>
        <groupId>com.101tec</groupId>
        <artifactId>zkclient</artifactId>
        <version>0.7</version>
    </dependency>
    

    Code:

    import java.util.Properties;
    
    import org.I0Itec.zkclient.ZkClient;
    import org.I0Itec.zkclient.ZkConnection;
    
    import kafka.admin.AdminUtils;
    import kafka.utils.ZKStringSerializer$;
    import kafka.utils.ZkUtils;
    
    public class KafkaJavaExample {
    
        public static void main(String[] args) {
            String zookeeperConnect = "zkserver1:2181,zkserver2:2181";
            int sessionTimeoutMs = 10 * 1000;
            int connectionTimeoutMs = 8 * 1000;
    
            ZkClient zkClient = new ZkClient(
                zookeeperConnect,
                sessionTimeoutMs,
                connectionTimeoutMs,
                ZKStringSerializer$.MODULE$);
    
           // Security for Kafka was added in Kafka 0.9.0.0
           boolean isSecureKafkaCluster = false;
           // ZkUtils for Kafka was used in Kafka 0.9.0.0 for the AdminUtils API
           ZkUtils zkUtils = new ZkUtils(zkClient, new ZkConnection(zookeeperConnect), isSecureKafkaCluster);
    
           String topic = "my-topic";
           int partitions = 2;
           int replication = 3;
    
           // Add topic configuration here
           Properties topicConfig = new Properties();
    
           AdminUtils.createTopic(zkUtils, topic, partitions, replication, topicConfig);
           zkClient.close();
        }
    }
    

    If you are wondering why the code below doesn't look like Java:

    ZKStringSerializer$.MODULE$
    

    It is because ZkStringSerializer is a Scala Object. You can read more information about that here:

    How create Kafka ZKStringSerializer in Java?

    Note: You must initialize the ZkClient with ZKStringSerializer.
    If you don't, then createTopic() will only seem to work (In other words: it will return without error).
    The topic will exist in only Zookeeper and only works when listing topics. i.e. list command below works fine

    bin/kafka-topics.sh --list --zookeeper localhost:2181
    

    but Kafka itself does not create the topic. To illustrate, the describe command below will throw an error.

    bin/kafka-topics.sh --describe --zookeeper localhost:2181
    

    Therefore, make sure you initialize it with ZKStringSerializer$.MODULE$.

    References: How Can we create a topic in Kafka from the IDE using API‌​from-the-ide-using-api

    Soon Chee Loong, University of Toronto

    0 讨论(0)
提交回复
热议问题