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


Java ConsumerConnector.commitOffsets方法代碼示例

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


在下文中一共展示了ConsumerConnector.commitOffsets方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的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: commit

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
@Override
public void commit() {
    ConsumerConnector connector = this.connector;
    if (connector != null) {
        connector.commitOffsets();
    }
}
 
開發者ID:shunfei,項目名稱:indexr,代碼行數:8,代碼來源:Kafka08Fetcher.java

示例6: main

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
public static void main(String[] args) {
	args = new String[] { "zookeeper0:2181/kafka", "topic1", "group2", "consumer1" };
	if (args == null || args.length != 4) {
		System.err.println("Usage:\n\tjava -jar kafka_consumer.jar ${zookeeper_list} ${topic_name} ${group_name} ${consumer_id}");
		System.exit(1);
	}
	String zk = args[0];
	String topic = args[1];
	String groupid = args[2];
	String consumerid = args[3];
	Properties props = new Properties();
	props.put("zookeeper.connect", zk);
	props.put("group.id", groupid);
	props.put("client.id", "test");
	props.put("consumer.id", consumerid);
	props.put("auto.offset.reset", "largest");
	props.put("auto.commit.enable", "false");
	props.put("auto.commit.interval.ms", "60000");

	ConsumerConfig consumerConfig = new ConsumerConfig(props);
	ConsumerConnector consumerConnector = Consumer.createJavaConsumerConnector(consumerConfig);

	Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
	topicCountMap.put(topic, 1);
	Map<String, List<KafkaStream<byte[], byte[]>>> consumerMap = consumerConnector.createMessageStreams(topicCountMap);

	KafkaStream<byte[], byte[]> stream1 = consumerMap.get(topic).get(0);
	ConsumerIterator<byte[], byte[]> interator = stream1.iterator();
	while (interator.hasNext()) {
		MessageAndMetadata<byte[], byte[]> messageAndMetadata = interator.next();
		String message = String.format(
				"Topic:%s, GroupID:%s, Consumer ID:%s, PartitionID:%s, Offset:%s, Message Key:%s, Message Payload: %s",
				messageAndMetadata.topic(), groupid, consumerid, messageAndMetadata.partition(),
				messageAndMetadata.offset(), new String(messageAndMetadata.key()),
				new String(messageAndMetadata.message()));
		System.out.println(message);
		consumerConnector.commitOffsets();
	}
}
 
開發者ID:habren,項目名稱:KafkaExample,代碼行數:40,代碼來源:DemoHighLevelConsumer.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: commitOffset

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
@Override
protected void commitOffset()
{
  // commit the offsets at checkpoint so that high-level consumer don't
  // have to receive too many duplicate messages
  if (standardConsumer != null && standardConsumer.values() != null) {
    for (ConsumerConnector consumerConnector : standardConsumer.values()) {
      consumerConnector.commitOffsets();
    }
  }
}
 
開發者ID:apache,項目名稱:apex-malhar,代碼行數:12,代碼來源:HighlevelKafkaConsumer.java

示例9: commitConsumerOffsets

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
static void commitConsumerOffsets(String groupId) {
	String consumerKey = groupId + "|" + Thread.currentThread().getName();
	ConsumerConnector consumerConnector = groupConsumers.get(consumerKey);
	if (consumerConnector != null) {
		consumerConnector.commitOffsets();
		LOG.debug("[EF-Msg] Commit: " + groupId);
	}
}
 
開發者ID:linzhaoming,項目名稱:easyframe-msg,代碼行數:9,代碼來源:KafkaHelper.java

示例10: consume

import kafka.javaapi.consumer.ConsumerConnector; //導入方法依賴的package包/類
@SuppressWarnings("InfiniteLoopStatement")
private static void consume(ConsumerConnector consumer, KafkaStream<byte[], byte[]> stream) throws Exception {
    for(ConsumerIterator<byte[],byte[]> i = stream.iterator();;) {
        out.println("Waiting for requests on \"" + id + "\" topic ...");

        MessageAndMetadata<byte[],byte[]> message = i.next();
        Requests requests = new Requests(message.message());

        sendRequests(requests);
        consumer.commitOffsets();
    }
}
 
開發者ID:stealthly,項目名稱:punxsutawney,代碼行數:13,代碼來源:HttpClient.java

示例11: 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


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