当前位置: 首页>>代码示例>>Java>>正文


Java ConsumerConnector.createMessageStreams方法代码示例

本文整理汇总了Java中kafka.javaapi.consumer.ConsumerConnector.createMessageStreams方法的典型用法代码示例。如果您正苦于以下问题:Java ConsumerConnector.createMessageStreams方法的具体用法?Java ConsumerConnector.createMessageStreams怎么用?Java ConsumerConnector.createMessageStreams使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在kafka.javaapi.consumer.ConsumerConnector的用法示例。


在下文中一共展示了ConsumerConnector.createMessageStreams方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: open

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
public void open(Map map, TopologyContext topologyContext, SpoutOutputCollector spoutOutputCollector) {
    _collector = spoutOutputCollector;
    Properties props = new Properties();
    props.put("zookeeper.connect", conf.get(OSMIngest.ZOOKEEPERS));
    props.put("group.id", groupId);
    props.put("zookeeper.sync.time.ms", "200");
    props.put("auto.commit.interval.ms", "1000");
    ConsumerConfig consumerConfig = new ConsumerConfig(props);
    ConsumerConnector consumer = Consumer.createJavaConsumerConnector(consumerConfig);
    Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
    topicCountMap.put(topic, 1);
    Map<String, List<KafkaStream<String, String>>> consumerMap = consumer.createMessageStreams(topicCountMap, new StringDecoder(new VerifiableProperties()), new StringDecoder(new VerifiableProperties()));
    List<KafkaStream<String, String>> streams = consumerMap.get(topic);
    KafkaStream<String, String> stream = null;
    if (streams.size() == 1) {
        stream = streams.get(0);
    } else {
        log.error("Streams should be of size 1");
    }
    kafkaIterator = stream.iterator();
}
 
开发者ID:geomesa,项目名称:geomesa-tutorials,代码行数:22,代码来源:OSMKafkaSpout.java

示例2: readTopicToList

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
/**
 * Read topic to list, only using Kafka code.
 */
private static List<MessageAndMetadata<byte[], byte[]>> readTopicToList(String topicName, ConsumerConfig config, final int stopAfter) {
	ConsumerConnector consumerConnector = Consumer.createJavaConsumerConnector(config);
	// we request only one stream per consumer instance. Kafka will make sure that each consumer group
	// will see each message only once.
	Map<String,Integer> topicCountMap = Collections.singletonMap(topicName, 1);
	Map<String, List<KafkaStream<byte[], byte[]>>> streams = consumerConnector.createMessageStreams(topicCountMap);
	if (streams.size() != 1) {
		throw new RuntimeException("Expected only one message stream but got "+streams.size());
	}
	List<KafkaStream<byte[], byte[]>> kafkaStreams = streams.get(topicName);
	if (kafkaStreams == null) {
		throw new RuntimeException("Requested stream not available. Available streams: "+streams.toString());
	}
	if (kafkaStreams.size() != 1) {
		throw new RuntimeException("Requested 1 stream from Kafka, bot got "+kafkaStreams.size()+" streams");
	}
	LOG.info("Opening Consumer instance for topic '{}' on group '{}'", topicName, config.groupId());
	ConsumerIterator<byte[], byte[]> iteratorToRead = kafkaStreams.get(0).iterator();

	List<MessageAndMetadata<byte[], byte[]>> result = new ArrayList<>();
	int read = 0;
	while(iteratorToRead.hasNext()) {
		read++;
		result.add(iteratorToRead.next());
		if (read == stopAfter) {
			LOG.info("Read "+read+" elements");
			return result;
		}
	}
	return result;
}
 
开发者ID:axbaretto,项目名称:flink,代码行数:35,代码来源:KafkaConsumerTestBase.java

示例3: addNewConsumer

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
public void addNewConsumer(String topic, Integer threads){
	ConsumerConnector consumer = consumerConnMap.get(topic);
	Map<String, List<KafkaStream<byte[], byte[]>>> consumerMap = null;
	
	Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
	topicCountMap.put(topic, threads);
	consumerMap = consumer.createMessageStreams(topicCountMap);
	
	List<KafkaStream<byte[], byte[]>> streams = consumerMap.get(topic);
	ExecutorService executor = Executors.newFixedThreadPool(threads);

	for (final KafkaStream<byte[], byte[]> stream : streams) {
		executor.submit(new Consumer(stream, this));
	}
	
	executorMap.put(topic, executor);
}
 
开发者ID:DTStack,项目名称:jlogstash-input-plugin,代码行数:18,代码来源:KafkaDistributed.java

示例4: consume

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
/**消费消息  [指定Topic]
 * 
 * @param topicName 队列名称
 * @param groupId Group Name
 * @return
 */
static MsgIterator consume(String topicName, String groupId) {
	ConsumerConnector consumerConnector = KafkaHelper.getConsumer(groupId);
	
	Map<String, Integer> topicCountMap = new HashMap<String, Integer>();	//(topic, #stream) pair
	topicCountMap.put(topicName, new Integer(1));

	//TODO: 可消费多个topic
	Map<String, List<KafkaStream<byte[], byte[]>>> consumerMap = consumerConnector.createMessageStreams(topicCountMap);	//Using default decoder
	List<KafkaStream<byte[], byte[]>> streamList = consumerMap.get(topicName);	//The number of items in the list is #streams, Each Stream supoorts an iterator over message/metadata pair
	KafkaStream<byte[], byte[]> stream = streamList.get(0);
	
	//KafkaStream[K,V] K代表partitio Key的类型,V代表Message Value的类型
	ConsumerIterator<byte[], byte[]> it = stream.iterator();
	MsgIterator iter = new MsgIterator(it);
	return iter;
}
 
开发者ID:linzhaoming,项目名称:easyframe-msg,代码行数:23,代码来源:KafkaHelper.java

示例5: kafkaStream

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
@Bean
protected KafkaStream<String, float[]> kafkaStream() {

    final String topicName = retrieveTopicNameFromGatewayAddress(gatewayUrl());

    ConsumerConnector consumerConnector =
            Consumer.createJavaConsumerConnector(consumerConfig());
    Map<String, Integer> topicCounts = new HashMap<>();
    topicCounts.put(topicName, 1);
    VerifiableProperties emptyProps = new VerifiableProperties();
    StringDecoder keyDecoder = new StringDecoder(emptyProps);
    FeatureVectorDecoder valueDecoder = new FeatureVectorDecoder();
    Map<String, List<KafkaStream<String, float[]>>> streams =
            consumerConnector.createMessageStreams(topicCounts, keyDecoder, valueDecoder);
    List<KafkaStream<String, float[]>> streamsByTopic = streams.get(topicName);
    Preconditions.checkNotNull(streamsByTopic, String.format("Topic %s not found in streams map.", topicName));
    Preconditions.checkElementIndex(0, streamsByTopic.size(),
            String.format("List of streams of topic %s is empty.", topicName));
    return streamsByTopic.get(0);
}
 
开发者ID:trustedanalytics,项目名称:space-shuttle-demo,代码行数:21,代码来源:KafkaConfiguration.java

示例6: createKafkaStream

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
public List<KafkaStream<byte[], byte[]>> createKafkaStream(
    String zookeeperConnectString,
    String topic,
    int partitions
) {
  //create consumer
  Properties consumerProps = new Properties();
  consumerProps.put("zookeeper.connect", zookeeperConnectString);
  consumerProps.put("group.id", "testClient");
  consumerProps.put("zookeeper.session.timeout.ms", "6000");
  consumerProps.put("zookeeper.sync.time.ms", "200");
  consumerProps.put("auto.commit.interval.ms", "1000");
  consumerProps.put("consumer.timeout.ms", "500");
  ConsumerConfig consumerConfig = new ConsumerConfig(consumerProps);
  ConsumerConnector consumer = Consumer.createJavaConsumerConnector(consumerConfig);
  Map<String, Integer> topicCountMap = new HashMap<>();
  topicCountMap.put(topic, partitions);
  Map<String, List<KafkaStream<byte[], byte[]>>> consumerMap = consumer.createMessageStreams(topicCountMap);
  return consumerMap.get(topic);
}
 
开发者ID:streamsets,项目名称:datacollector,代码行数:21,代码来源:SdcKafkaTestUtil.java

示例7: createKafkaStream

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
public static List<KafkaStream<byte[], byte[]>> createKafkaStream(String zookeeperConnectString, String topic, int partitions) {
  //create consumer
  Properties consumerProps = new Properties();
  consumerProps.put("zookeeper.connect", zookeeperConnectString);
  consumerProps.put("group.id", "testClient");
  consumerProps.put("zookeeper.session.timeout.ms", "6000");
  consumerProps.put("zookeeper.sync.time.ms", "200");
  consumerProps.put("auto.commit.interval.ms", "1000");
  consumerProps.put("consumer.timeout.ms", "500");
  ConsumerConfig consumerConfig = new ConsumerConfig(consumerProps);
  ConsumerConnector consumer = Consumer.createJavaConsumerConnector(consumerConfig);
  Map<String, Integer> topicCountMap = new HashMap<>();
  topicCountMap.put(topic, partitions);
  Map<String, List<KafkaStream<byte[], byte[]>>> consumerMap = consumer.createMessageStreams(topicCountMap);
  return consumerMap.get(topic);

}
 
开发者ID:streamsets,项目名称:datacollector,代码行数:18,代码来源:KafkaTestUtil.java

示例8: run

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
@Override
public void run() {
	int cpus = Runtime.getRuntime().availableProcessors();
	ExecutorService executor = Executors.newFixedThreadPool(cpus);
	
	ConsumerConnector consumer = kafka.consumer.Consumer
			.createJavaConsumerConnector(this.consumerConfig);

	// map topics to thread count
	Map<String, Integer> topicCountMap = new HashMap<>();
	topicCountMap.put(this.topic, threadsPerTopic);
	
	// map topics to list of streams (1 stream per thread per topic)
	Map<String, List<KafkaStream<String, TIn>>> consumerMap = consumer
			.createMessageStreams(topicCountMap, this.keyDecoder, this.valueDecoder);
	
	// actually create/submit threads
	for (final KafkaStream<String, TIn> stream : consumerMap.get(this.topic)) {
		executor.submit(new Consumer<String, TIn>(stream, dispatcherCommand));
	}

	// do not close producer while threads are still running
	// this.producer.close();
}
 
开发者ID:mpopp,项目名称:MIB,代码行数:25,代码来源:EventDispatcher.java

示例9: main

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
public static void main(String[] args) {
	Properties props = new Properties();
	props.put("zookeeper.connect","10.15.62.76:2181");
	props.put("group.id","mygroup001");
	props.put("zookeeper.session.timeout.ms","40000");
	props.put("zookeeper.sync.time.ms","200");
	props.put("auto.commit.interval.ms","1000");
	
	ConsumerConfig consumerConfig = new ConsumerConfig(props);
	
	ConsumerConnector consumer = kafka.consumer.Consumer.createJavaConsumerConnector(consumerConfig);
	
	Map<String,Integer> topicCountMap = new HashMap<String,Integer>();
	topicCountMap.put("my-topic",new Integer(1));
	System.out.println("zzzzzzzzzzzzz");
	Map<String,List<KafkaStream<byte[],byte[]>>> consumerMap = consumer.createMessageStreams(topicCountMap);
	List<KafkaStream<byte[], byte[]>> streams = consumerMap.get("my-topic");
	
	KafkaStream<byte[], byte[]> stream = streams.get(0);
	
	ConsumerIterator<byte[], byte[]> it = stream.iterator();
	System.out.println("before while...");
	while(it.hasNext()){
		System.out.println(new String(it.next().message()));
	}
}
 
开发者ID:YinYanfei,项目名称:CadalWorkspace,代码行数:27,代码来源:myConsumer.java

示例10: open

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
@SuppressWarnings("unchecked")
@Override
public void open(Map conf, TopologyContext context,
		SpoutOutputCollector collector) {
	this._collector = collector;
	
	
	Properties props = new Properties();
	props.put("zk.connect", "10.15.62.104:2181");
	props.put("groupid", "group1");

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

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

	Map<String, List<KafkaMessageStream>> consumerMap = consumer
			.createMessageStreams(topicCountMap);

	KafkaMessageStream stream = consumerMap.get("newtopic").get(0);
	
	this.it = stream.iterator();		
}
 
开发者ID:YinYanfei,项目名称:CadalWorkspace,代码行数:26,代码来源:SpoutKafka.java

示例11: open

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
@SuppressWarnings("unchecked")
@Override
public void open(Map conf, TopologyContext context,
		SpoutOutputCollector collector) {
	this._collector = collector;
	this.logger = Logger.getLogger(BoltCassandra.class.getClass().getName());
	
	// Construct kafka part
	Properties props = new Properties();
	props.put("zk.connect", "10.15.62.75:2181");
	props.put("groupid", "sec-group-1");		// 

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

	Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
	topicCountMap.put("sec-stream-one", new Integer(1));		// 

	Map<String, List<KafkaMessageStream>> consumerMap = consumer.createMessageStreams(topicCountMap);

	KafkaMessageStream stream = consumerMap.get("sec-stream-one").get(0);		//
	
	this.it = stream.iterator();
}
 
开发者ID:YinYanfei,项目名称:CadalWorkspace,代码行数:25,代码来源:SpoutKafka.java

示例12: KafkaInit

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
private void KafkaInit(){
	Properties props = new Properties();
	props.put("zookeeper.connect", "10.15.62.75:2181,10.15.62.76:2181,10.15.62.77:2181");
	props.put("group.id", "RecRecPage");
	
	ConsumerConfig consumerConfig = new ConsumerConfig(props);
	ConsumerConnector consumer = kafka.consumer.Consumer.createJavaConsumerConnector(consumerConfig);

	Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
	topicCountMap.put("Rec-recPage", new Integer(1));// 第二个参数是指用几个流,多个流是为了并行处理。

	Map<String, List<KafkaStream<byte[],byte[]>>> consumerMap = consumer.createMessageStreams(topicCountMap);

	KafkaStream<byte[], byte[]> stream = consumerMap.get("Rec-recPage").get(0);// 这里只有一个流,所以得get(0)就可以了。
	this.it = stream.iterator();
}
 
开发者ID:YinYanfei,项目名称:CadalWorkspace,代码行数:17,代码来源:RecBookRecPageSpout.java

示例13: KafkaInit

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
private void KafkaInit(){
	Properties props = new Properties();
	props.put("zookeeper.connect", "10.15.62.75:2181,10.15.62.76:2181,10.15.62.77:2181");
	props.put("group.id", "RecTagRecPage");
	
	ConsumerConfig consumerConfig = new ConsumerConfig(props);
	ConsumerConnector consumer = kafka.consumer.Consumer.createJavaConsumerConnector(consumerConfig);

	Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
	topicCountMap.put("Rec-recPageTagTag", new Integer(1));// 第二个参数是指用几个流,多个流是为了并行处理。

	Map<String, List<KafkaStream<byte[],byte[]>>> consumerMap = consumer.createMessageStreams(topicCountMap);

	KafkaStream<byte[], byte[]> stream = consumerMap.get("Rec-recPageTagTag").get(0);// 这里只有一个流,所以得get(0)就可以了。
	this.it = stream.iterator();
}
 
开发者ID:YinYanfei,项目名称:CadalWorkspace,代码行数:17,代码来源:RecTagRecPageSpout.java

示例14: KafkaInit

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
private void KafkaInit(){
	Properties props = new Properties();
	props.put("zookeeper.connect", "10.15.62.75:2181,10.15.62.76:2181,10.15.62.77:2181");
	props.put("group.id", "RecPersonalPage");
	
	ConsumerConfig consumerConfig = new ConsumerConfig(props);
	ConsumerConnector consumer = kafka.consumer.Consumer.createJavaConsumerConnector(consumerConfig);

	Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
	topicCountMap.put("Rec-personalPage", new Integer(1));// 第二个参数是指用几个流,多个流是为了并行处理。

	Map<String, List<KafkaStream<byte[],byte[]>>> consumerMap = consumer.createMessageStreams(topicCountMap);

	KafkaStream<byte[], byte[]> stream = consumerMap.get("Rec-personalPage").get(0);// 这里只有一个流,所以得get(0)就可以了。
	this.it = stream.iterator();
}
 
开发者ID:YinYanfei,项目名称:CadalWorkspace,代码行数:17,代码来源:RecBookPersonalPageSpout.java

示例15: KafkaInit

import kafka.javaapi.consumer.ConsumerConnector; //导入方法依赖的package包/类
private void KafkaInit(){
	Properties props = new Properties();
	props.put("zookeeper.connect", "10.15.62.75:2181,10.15.62.76:2181,10.15.62.77:2181");
	props.put("group.id", "RecTagBook");
	
	ConsumerConfig consumerConfig = new ConsumerConfig(props);
	ConsumerConnector consumer = kafka.consumer.Consumer.createJavaConsumerConnector(consumerConfig);

	Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
	topicCountMap.put("Rec-recPageTagBook", new Integer(1));// 第二个参数是指用几个流,多个流是为了并行处理。

	Map<String, List<KafkaStream<byte[],byte[]>>> consumerMap = consumer.createMessageStreams(topicCountMap);

	KafkaStream<byte[], byte[]> stream = consumerMap.get("Rec-recPageTagBook").get(0);// 这里只有一个流,所以得get(0)就可以了。
	this.it = stream.iterator();
}
 
开发者ID:YinYanfei,项目名称:CadalWorkspace,代码行数:17,代码来源:RecTagBookSpout.java


注:本文中的kafka.javaapi.consumer.ConsumerConnector.createMessageStreams方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。