/** * Copyright © 2016-2017 The Thingsboard Authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.thingsboard.server.extensions.kafka; import kafka.server.KafkaConfig; import kafka.server.KafkaServerStartable; import org.apache.zookeeper.server.ServerConfig; import org.apache.zookeeper.server.ZooKeeperServerMain; import org.apache.zookeeper.server.quorum.QuorumPeerConfig; import java.io.File; import java.io.IOException; import java.util.Properties; public class KafkaDemoClient { private static final int ZK_PORT = 2222; private static final String HOSTNAME = "localhost"; private static final String ZOOKEEPER_CONNECT = HOSTNAME + ":" + ZK_PORT; private static final int KAFKA_PORT = 9092; private static final int BROKER_ID = 1; public static void main(String[] args) { try { startZkLocal(); startKafkaLocal(); } catch (Exception e) { System.out.println("Error running local Kafka broker"); e.printStackTrace(System.out); } } private static void startZkLocal() throws Exception { final File zkTmpDir = File.createTempFile("zookeeper", "test"); if (zkTmpDir.delete() && zkTmpDir.mkdir()) { Properties zkProperties = new Properties(); zkProperties.setProperty("dataDir", zkTmpDir.getAbsolutePath()); zkProperties.setProperty("clientPort", String.valueOf(ZK_PORT)); ServerConfig configuration = new ServerConfig(); QuorumPeerConfig quorumConfiguration = new QuorumPeerConfig(); quorumConfiguration.parseProperties(zkProperties); configuration.readFrom(quorumConfiguration); new Thread() { public void run() { try { new ZooKeeperServerMain().runFromConfig(configuration); } catch (IOException e) { System.out.println("Start of Local ZooKeeper Failed"); e.printStackTrace(System.err); } } }.start(); } else { System.out.println("Failed to delete or create data dir for Zookeeper"); } } private static void startKafkaLocal() { Properties kafkaProperties = new Properties(); kafkaProperties.setProperty("host.name", HOSTNAME); kafkaProperties.setProperty("port", String.valueOf(KAFKA_PORT)); kafkaProperties.setProperty("broker.id", String.valueOf(BROKER_ID)); kafkaProperties.setProperty("zookeeper.connect", ZOOKEEPER_CONNECT); KafkaConfig kafkaConfig = new KafkaConfig(kafkaProperties); KafkaServerStartable kafka = new KafkaServerStartable(kafkaConfig); kafka.startup(); } }