博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
26.4. 线程例子
阅读量:7081 次
发布时间:2019-06-28

本文共 2499 字,大约阅读时间需要 8 分钟。

 

package cn.netkiller.ipo.test;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Properties;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.KafkaConsumer;
import org.apache.kafka.common.errors.WakeupException;
import org.apache.kafka.common.serialization.StringDeserializer;
public class KafkaConsumerThread implements Runnable {
private final KafkaConsumer<String, String> consumer;
private final List<String> topics;
public KafkaConsumerThread(String groupId, List<String> topics) {
this.topics = topics;
Properties props = new Properties();
props.put("bootstrap.servers", "kafka.netkiller.cn:9092");
props.put("group.id", groupId);
props.put("key.deserializer", StringDeserializer.class.getName());
props.put("value.deserializer", StringDeserializer.class.getName());
this.consumer = new KafkaConsumer<String, String>(props);
}
public void run() {
try {
consumer.subscribe(this.topics);
while (true) {
ConsumerRecords<String, String> records = consumer.poll(Long.MAX_VALUE);
for (ConsumerRecord<String, String> record : records) {
Map<String, Object> data = new HashMap<>();
data.put("partition", record.partition());
data.put("offset", record.offset());
data.put("value", record.value());
System.out.println(data);
}
}
} catch (WakeupException e) {
// ignore for shutdown
} finally {
consumer.close();
}
}
public void shutdown() {
consumer.wakeup();
}
public static void main(String[] args) {
int numConsumers = 3;
String groupId = "consumer-tutorial-group";
List<String> topics = Arrays.asList("test");
ExecutorService executor = Executors.newFixedThreadPool(numConsumers);
final List<KafkaConsumerThread> consumers = new ArrayList<>();
for (int i = 0; i < numConsumers; i++) {
KafkaConsumerThread consumer = new KafkaConsumerThread(groupId, topics);
consumers.add(consumer);
executor.submit(consumer);
}
Runtime.getRuntime().addShutdownHook(new Thread() {
@Override
public void run() {
for (KafkaConsumerThread consumer : consumers) {
consumer.shutdown();
}
executor.shutdown();
try {
executor.awaitTermination(5000, TimeUnit.MILLISECONDS);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
}
}
  
 

原文出处:Netkiller 系列 手札
本文作者:陈景峯
转载请与作者联系,同时请务必标明文章原始出处和作者信息及本声明。

你可能感兴趣的文章
Yii 框架之采用自带的jquery库实现ajax分页
查看>>
Android广播-个人总结
查看>>
Mybatis 框架源码分析
查看>>
关于 LF will be replaced by CRLF 问题出现的原因以及解决方式
查看>>
HTML5编程之旅 第3站 WebSockets
查看>>
oracle 体系结构及内存管理 05_重建EM
查看>>
everedit
查看>>
改写源代码,使得认证成功后跳转到successUrl路径
查看>>
浅析CentOS和RedHat Linux的区别
查看>>
Linux gcc版本如何升级
查看>>
Lubuntu Next 18.10将默认采用Calamares
查看>>
思达报表工具Style Report基础教程—简单列表
查看>>
一个灵活、好用、扩展性好的WCM系统应该包含哪些功能
查看>>
JAVA IO - 压缩流
查看>>
网络客户端的几种模式
查看>>
hive 新加字段 插入数据 注意事项
查看>>
Gstreamer学习笔记----第一个helloworld程序
查看>>
unix编程之多进程编程
查看>>
R语言学习之聚类
查看>>
我的友情链接
查看>>