當前位置: 首頁>>代碼示例>>Java>>正文


Java ConsumerConnector.shutdown方法代碼示例

本文整理匯總了Java中kafka.javaapi.consumer.ConsumerConnector.shutdown方法的典型用法代碼示例。如果您正苦於以下問題:Java ConsumerConnector.shutdown方法的具體用法?Java ConsumerConnector.shutdown怎麽用?Java ConsumerConnector.shutdown使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在kafka.javaapi.consumer.ConsumerConnector的用法示例。


在下文中一共展示了ConsumerConnector.shutdown方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: release

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
@Override
public void release() {
	try {
		for(ConsumerConnector consumer : consumerConnMap.values()){
			consumer.commitOffsets(true);
			consumer.shutdown();
		}
		for(ExecutorService executor : executorMap.values()){
			executor.shutdownNow();
		}

		if(scheduleExecutor != null){
			scheduleExecutor.shutdownNow();
		}

		this.zkDistributed.realse();
	} catch (Exception e) {
		// TODO Auto-generated catch block
		logger.error(ExceptionUtil.getErrorMessage(e));
	}
}
 
開發者ID:DTStack,項目名稱:jlogstash-input-plugin,代碼行數:22,代碼來源:KafkaDistributed.java

示例2: close

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
@Override
public synchronized void close() throws IOException {
    logger.debug("Stop kafka fetcher. [topic: {}]", topics);
    ConsumerConnector connector = this.connector;
    this.connector = null;
    if (connector != null) {
        connector.commitOffsets();
        connector.shutdown();
    }

    IOUtil.closeQuietly(eventItr);
    // Some events could exists in the buffer, try to save them.
    List<byte[]> remaining = new ArrayList<>();
    try {
        while (eventItr.hasNext()) {
            remaining.add(eventItr.next());
        }
    } catch (Exception e) {
        // Ignore
    }
    eventItr = null;
    if (!remaining.isEmpty()) {
        this.remaining = remaining;
    }
}
 
開發者ID:shunfei,項目名稱:indexr,代碼行數:26,代碼來源:Kafka08Fetcher.java

示例3: reconnConsumer

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
public void reconnConsumer(String topicName){
		
		//停止topic 對應的conn
		ConsumerConnector consumerConn = consumerConnMap.get(topicName);
		consumerConn.commitOffsets(true);
		consumerConn.shutdown();
		consumerConnMap.remove(topicName);
		
		//停止topic 對應的stream消耗線程
		ExecutorService es = executorMap.get(topicName);
		es.shutdownNow();
		executorMap.remove(topicName);

		Properties prop = geneConsumerProp();
		ConsumerConnector newConsumerConn = kafka.consumer.Consumer
				.createJavaConsumerConnector(new ConsumerConfig(prop));
		consumerConnMap.put(topicName, newConsumerConn);

		addNewConsumer(topicName, topic.get(topicName));
}
 
開發者ID:DTStack,項目名稱:jlogstash-input-plugin,代碼行數:21,代碼來源:KafkaDistributed.java

示例4: reconnConsumer

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
public void reconnConsumer(String topicName){
	
	//停止topic 對應的conn
	ConsumerConnector consumerConn = consumerConnMap.get(topicName);
	consumerConn.commitOffsets(true);
	consumerConn.shutdown();
	consumerConnMap.remove(topicName);
	
	//停止topic 對應的stream消耗線程
	ExecutorService es = executorMap.get(topicName);
	es.shutdownNow();	
	executorMap.remove(topicName);
	
	Properties prop = geneConsumerProp();
	ConsumerConnector newConsumerConn = kafka.consumer.Consumer
			.createJavaConsumerConnector(new ConsumerConfig(prop));
	consumerConnMap.put(topicName, newConsumerConn);
	
	addNewConsumer(topicName, topic.get(topicName));
}
 
開發者ID:DTStack,項目名稱:jlogstash-input-plugin,代碼行數:21,代碼來源:Kafka.java

示例5: getVehicleStartPoints

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
private static Map<String, Location> getVehicleStartPoints() {
	Map<String, Location> vehicleStartPoint = new HashMap<String, Location>();
	Properties props = new Properties();
	props.put("zookeeper.connect", ZOOKEEPER_CONNECTION_STRING);
	props.put("group.id", "DataLoader" + r.nextInt(100));
	props.put("key.deserializer", StringDeserializer.class.getName());
	props.put("value.deserializer", StringDeserializer.class.getName());
	props.put("auto.offset.reset", "smallest");

	ConsumerConnector consumer = Consumer.createJavaConsumerConnector(new ConsumerConfig(props));

	Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
	topicCountMap.put(KAFKA_TOPIC_STATIC_DATA, new Integer(1)); 

	KafkaStream<byte[], byte[]> stream = consumer.createMessageStreams(topicCountMap).get(KAFKA_TOPIC_STATIC_DATA)
			.get(0);

	ConsumerIterator<byte[], byte[]> it = stream.iterator();

	while (it.hasNext()) {
		String message = new String(it.next().message());
		try {
			vehicleStartPoint = objectMapper.readValue(message, new TypeReference<Map<String, Location>>() {
			});
		} catch (IOException e) {
			e.printStackTrace();
		}
		break;
	}
	consumer.shutdown();
	return vehicleStartPoint;
}
 
開發者ID:PacktPublishing,項目名稱:Practical-Real-time-Processing-and-Analytics,代碼行數:33,代碼來源:VehicleDataGeneration.java

示例6: run

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
@Override
public void run() {
  long relayed = 0;
  
  LOG.info("Starting relay");
  final ConsumerConnector consumer = Consumer.createJavaConsumerConnector(createConsumerConfig());
  final KafkaStream<byte[], byte[]> stream = createConsumerStream(consumer);
  
  final Producer<byte[], byte[]> producer = new Producer<>(createProducerConfig());
  final ConsumerIterator<byte[], byte[]> it = stream.iterator();
  while (it.hasNext()) {
    final MessageAndMetadata<byte[], byte[]> rx = it.next();
    relayed++;
    if (LOG.isTraceEnabled()) LOG.trace("Relaying {}/{}: key={}, value={}",
                                        relayed,
                                        maxRecords != 0 ? maxRecords : "\u221E",
                                        new String(rx.key()),
                                        new String(rx.message()));
    final KeyedMessage<byte[], byte[]> tx = new KeyedMessage<>(config.sink.topic, rx.key(), rx.message());
    producer.send(tx);
    
    if (maxRecords != 0 && relayed >= maxRecords) {
      LOG.info("Shutting down");
      break;
    }
  }

  producer.close();
  consumer.shutdown();
}
 
開發者ID:William-Hill-Community,項目名稱:rekafka,代碼行數:31,代碼來源:Relay.java

示例7: release

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
@Override
public void release() {
	
	for(ConsumerConnector consumer : consumerConnMap.values()){
		consumer.commitOffsets(true);
		consumer.shutdown();
	}
	
	for(ExecutorService executor : executorMap.values()){
		executor.shutdownNow();
	}
	
	scheduleExecutor.shutdownNow();
}
 
開發者ID:DTStack,項目名稱:jlogstash-input-plugin,代碼行數:15,代碼來源:Kafka.java

示例8: close

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
@Override
public void close()
{
  if (standardConsumer != null && standardConsumer.values() != null) {
    for (ConsumerConnector consumerConnector : standardConsumer.values()) {
      consumerConnector.shutdown();
    }
  }
  if (consumerThreadExecutor != null) {
    consumerThreadExecutor.shutdown();
  }
}
 
開發者ID:apache,項目名稱:apex-malhar,代碼行數:13,代碼來源:HighlevelKafkaConsumer.java

示例9: shutdownConsummer

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
static void shutdownConsummer(String groupId){
	String consumerKey = groupId + "|" + Thread.currentThread().getName();
	ConsumerConnector consumerConnector = groupConsumers.get(consumerKey);
	try{
		consumerLock.lock();
		consumerConnector = groupConsumers.get(consumerKey);
		if (consumerConnector != null ) {
			consumerConnector.shutdown();
			groupConsumers.remove(consumerKey);
			consumerConnector = null;
		}
	}finally{
		consumerLock.unlock();
	}
}
 
開發者ID:linzhaoming,項目名稱:easyframe-msg,代碼行數:16,代碼來源:KafkaHelper.java

示例10: main

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
public static void main(String[] args) {
	
	// String group = args[0] ;
	String group = "manoj" ;
	
	
	Properties props = new Properties();
       props.put("zookeeper.connect", "localhost:2181");
       props.put("group.id", group);
       props.put("zookeeper.session.timeout.ms", "413");
       props.put("zookeeper.sync.time.ms", "203");
       props.put("auto.commit.interval.ms", "1000");
       // props.put("auto.offset.reset", "smallest");
	
       ConsumerConfig cf = new ConsumerConfig(props) ;
       
       ConsumerConnector consumer = Consumer.createJavaConsumerConnector(cf) ;
       
       String topic = "mjtopic" ;
       
       Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
       topicCountMap.put(topic, new Integer(1));
       Map<String, List<KafkaStream<byte[], byte[]>>> consumerMap = consumer.createMessageStreams(topicCountMap);
       List<KafkaStream<byte[], byte[]>> streams = consumerMap.get(topic);


       KafkaStream<byte[],byte[]> stream = streams.get(0) ;
       
       ConsumerIterator<byte[], byte[]> it = stream.iterator();
       int i = 1 ;
       while (it.hasNext()) {
           System.out.println(i + ": " + new String(it.next().message()));
           ++i;
       }
       
       consumer.shutdown(); 
}
 
開發者ID:mdkhanga,項目名稱:my-blog-code,代碼行數:38,代碼來源:KafkaConsumer.java

示例11: main

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {

        final MetricRegistry metricRegistry = new MetricRegistry();
        final Meter meter = metricRegistry.meter("throughput");
        final ConsoleReporter reporter = ConsoleReporter.forRegistry(metricRegistry)
                .convertRatesTo(TimeUnit.SECONDS)
                .convertDurationsTo(TimeUnit.MILLISECONDS)
                .build();
        reporter.start(1, TimeUnit.MINUTES);

        final Properties properties = new Properties();
        properties.setProperty("zookeeper.connect", "localhost:2181");
        properties.setProperty("group.id", "myclient");
        properties.setProperty("zookeeper.session.timeout.ms", "400");
        properties.setProperty("zookeeper.sync.time.ms", "200");
        properties.setProperty("auto.commit.interval.ms", "1000");
        properties.setProperty("auto.offset.reset", "smallest");
        properties.setProperty("consumer.timeout.ms", "10000");

        final ConsumerConfig consumerConfig = new ConsumerConfig(properties);

        final String topic = "csc8101";
        final int numThreads = 4;

        final ConsumerConnector consumerConnector = Consumer.createJavaConsumerConnector(consumerConfig);
        final Map<String, Integer> topicCountMap = new HashMap<>();
        topicCountMap.put(topic, numThreads);
        final Decoder<String> decoder = new StringDecoder(new VerifiableProperties());
        final Map<String, List<KafkaStream<String, String>>> streamsMap =
                consumerConnector.createMessageStreams(topicCountMap, decoder, decoder);

        final ExecutorService executorService = Executors.newFixedThreadPool(numThreads);

        for(final KafkaStream<String, String> stream : streamsMap.get(topic)) {
            final MessageHandler messageHandler = new MessageHandler();
            final RunnableConsumer runnableConsumer = new RunnableConsumer(stream, messageHandler, meter);
            executorService.submit(runnableConsumer);
        }

        executorService.shutdown();
        executorService.awaitTermination(Long.MAX_VALUE, TimeUnit.HOURS);

        consumerConnector.shutdown();

        MessageHandler.close();

        reporter.report();
        reporter.stop();

        // we use the newer version of metrics, which shuts itself down cleanly. But...
        // kafka still uses the old one and doesn't shut it down properly,
        // leaving some metrics-meter-tick-thread lying around. So to avoid
        // java.lang.IllegalThreadStateException from mvn:exec wrapper we terminate it explicitly here
        com.yammer.metrics.Metrics.defaultRegistry().shutdown();

        // bin/kafka-run-class.sh kafka.tools.ConsumerOffsetChecker --zkconnect localhost:2181 --group myclient
    }
 
開發者ID:jhalliday,項目名稱:csc8101,代碼行數:58,代碼來源:KafkaConsumer.java

示例12: consumeFromTopic

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
public <T> void consumeFromTopic(
		final String formatPluginName,
		final AvroFormatPlugin<T, ?> avroFormatPlugin,
		final KafkaIngestRunData ingestRunData,
		final List<String> queue ) {

	final ConsumerConnector consumer = buildKafkaConsumer();
	if (consumer == null) {
		throw new RuntimeException(
				"Kafka consumer connector is null, unable to create message streams");
	}
	try {
		LOGGER.debug("Kafka consumer setup for format [" + formatPluginName + "] against topic ["
				+ formatPluginName + "]");
		final Map<String, Integer> topicCount = new HashMap<>();
		topicCount.put(
				formatPluginName,
				1);

		final Map<String, List<KafkaStream<byte[], byte[]>>> consumerStreams = consumer
				.createMessageStreams(topicCount);
		final List<KafkaStream<byte[], byte[]>> streams = consumerStreams.get(formatPluginName);

		queue.remove(formatPluginName);
		consumeMessages(
				formatPluginName,
				avroFormatPlugin,
				ingestRunData,
				streams.get(0));
	}
	finally {
		consumer.shutdown();
	}
}
 
開發者ID:locationtech,項目名稱:geowave,代碼行數:35,代碼來源:IngestFromKafkaDriver.java

示例13: consume

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
@GET
@Timed
public Response consume(
        @QueryParam("topic") String topic,
        @QueryParam("timeout") Integer timeout
) {
    if (Strings.isNullOrEmpty(topic))
        return Response.status(400)
                .entity(new String[]{"Undefined topic"})
                .build();

    Properties props = (Properties) consumerCfg.clone();
    if (timeout != null) props.put("consumer.timeout.ms", "" + timeout);

    ConsumerConfig config = new ConsumerConfig(props);
    ConsumerConnector connector = Consumer.createJavaConsumerConnector(config);

    Map<String, Integer> streamCounts = Collections.singletonMap(topic, 1);
    Map<String, List<KafkaStream<byte[], byte[]>>> streams = connector.createMessageStreams(streamCounts);
    KafkaStream<byte[], byte[]> stream = streams.get(topic).get(0);

    List<Message> messages = new ArrayList<>();
    try {
        for (MessageAndMetadata<byte[], byte[]> messageAndMetadata : stream)
            messages.add(new Message(messageAndMetadata));
    } catch (ConsumerTimeoutException ignore) {
    } finally {
        connector.commitOffsets();
        connector.shutdown();
    }

    return Response.ok(messages).build();
}
 
開發者ID:elodina,項目名稱:dropwizard-kafka-http,代碼行數:34,代碼來源:MessageResource.java

示例14: main

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
public static void main(String[] argv) {

        System.out.println("Start smoke test for kafka");

        // Basic kafka configuration and change for your kafka cluster
        String broker = "localhost:9092"; 
        String zookeeper = "localhost:2181";
        String topic = "test-topic";
        
        // New kafka producer
        Properties props = new Properties();
        props.put("metadata.broker.list", broker);
        props.put("serializer.class", "kafka.serializer.StringEncoder");
        props.put("partitioner.class", "cn.chendihao.SimplePartitioner");
        props.put("request.required.acks", "1");
        ProducerConfig config = new ProducerConfig(props);
        Producer<String, String> producer = new Producer<String, String>(config);


        // Produce data in kafka
        long events = 5;
        Random random = new Random();
        for (long nEvents = 0; nEvents < events; nEvents++) {
            long runtime = new Date().getTime();
            String ip = "192.168.2." + random.nextInt(255);
            String msg = runtime + ", www.example.com, " + ip;
            KeyedMessage<String, String> data = new KeyedMessage<String, String>(topic, ip, msg);
            producer.send(data);
            System.out.println("Success to insert message " + msg);
        }

        // Close producer
        producer.close();

        // New consumer
        String groupId = "test-group";
        Properties props2 = new Properties();
        props2.put("zookeeper.connect", zookeeper);
        props2.put("group.id", groupId);
        props2.put("zookeeper.session.timeout.ms", "400");
        props2.put("zookeeper.sync.time.ms", "200");
        props2.put("auto.commit.interval.ms", "1000");
        ConsumerConnector consumer = Consumer.createJavaConsumerConnector(new ConsumerConfig(props2));
        Map<String, Integer> topicCountMap = new HashMap<String, Integer>();

        // Consume data from kafka
        int threads = 1;
        topicCountMap.put(topic, threads);
        Map<String, List<KafkaStream<byte[], byte[]>>> consumerMap = consumer.createMessageStreams(topicCountMap);
        List<KafkaStream<byte[], byte[]>> streams = consumerMap.get(topic);
        //now launch all threads
        ExecutorService executor = Executors.newFixedThreadPool(threads);
        //now create an object to consume the messages
        int threadNum = 0;
        for (final KafkaStream stream : streams) {
            executor.submit(new ConsumerTest(stream, threadNum));
            threadNum++;
        }
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        // Recycle the resources
        if (consumer != null) {
            consumer.shutdown();
        }
        if (executor != null) {
            executor.shutdown();
        }

        System.out.println("Stop smoke test for kafka");

    }
 
開發者ID:tobegit3hub,項目名稱:smoke-kafka,代碼行數:76,代碼來源:SmokeKafka.java

示例15: testMultithread

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
@Test
public void testMultithread() throws IOException {
    TopicCommand.createTopic(zk.getZkClient(),
            new TopicCommand.TopicCommandOptions(new String[]{
                    "--zookeeper", "dummy", "--create", "--topic", TOPIC_NAME_MULTITHREAD,
                    "--replication-factor", "2", "--partitions", "1"}));
    String description = "{\n" +
            "    \"type\": \"kafka\",\n" +
            "    \"client.id\": \"kafkasink\",\n" +
            "    \"metadata.broker.list\": \"" + kafkaServer.getBrokerListStr() + "\",\n" +
            "    \"request.required.acks\": 1,\n" +
            "    \"batchSize\": 10,\n" +
            "    \"jobQueueSize\": 3\n" +
            "}";

    ObjectMapper jsonMapper = new DefaultObjectMapper();
    jsonMapper.registerSubtypes(new NamedType(KafkaSinkV2.class, "kafka"));
    KafkaSinkV2 sink = jsonMapper.readValue(description, new TypeReference<Sink>(){});
    sink.open();
    int msgCount = 10000;
    for (int i = 0; i < msgCount; ++i) {
        Map<String, Object> msgMap = new ImmutableMap.Builder<String, Object>()
                .put("key", Integer.toString(i))
                .put("value", "message:" + i).build();
        sink.writeTo(new DefaultMessageContainer(
                new Message(TOPIC_NAME_MULTITHREAD, jsonMapper.writeValueAsBytes(msgMap)),
                jsonMapper));
    }
    assertTrue(sink.getNumOfPendingMessages() > 0);
    sink.close();
    System.out.println(sink.getStat());
    assertEquals(sink.getNumOfPendingMessages(), 0);

    ConsumerConnector consumer = kafka.consumer.Consumer.createJavaConsumerConnector(
            createConsumerConfig("localhost:" + zk.getServerPort(), "gropuid_multhread"));
    Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
    topicCountMap.put(TOPIC_NAME_MULTITHREAD, 1);
    Map<String, List<KafkaStream<byte[], byte[]>>> consumerMap = consumer.createMessageStreams(topicCountMap);
    KafkaStream<byte[], byte[]> stream = consumerMap.get(TOPIC_NAME_MULTITHREAD).get(0);
    for (int i = 0; i < msgCount; ++i) {
        stream.iterator().next();
    }

    try {
        stream.iterator().next();
        fail();
    } catch (ConsumerTimeoutException e) {
        //this is expected
        consumer.shutdown();
    }
}
 
開發者ID:Netflix,項目名稱:suro,代碼行數:52,代碼來源:TestKafkaSinkV2.java


注:本文中的kafka.javaapi.consumer.ConsumerConnector.shutdown方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。