26.4. 线程例子

简介:

 

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 系列 手札
本文作者:陈景峯
转载请与作者联系,同时请务必标明文章原始出处和作者信息及本声明。

目录
相关文章
【多线程面试题十一】、如何实现子线程先执行,主线程再执行?
要实现子线程先执行,主线程再执行,可以在启动子线程后立即调用其join()方法,使主线程等待子线程执行完成。
三个线程交替打印ABC100次问题思考之二,使用信号量的优雅实现
三个线程交替打印ABC100次问题思考之二,使用信号量的优雅实现
103 0
|
Java
线程和进程概念区别—及线程常用方法和状态
进程和线程是操作系统中的两个基本概念。 进程是程序执行的基本单位,每个进程都有自己独立的内存空间和系统资源,它拥有自己的虚拟地址空间、代码段、数据段、堆栈段等。一个程序可以对应多个进程,每个进程之间是独立运行的,互相之间不会影响。
250 0
|
安全
线程3大不安全案例 1.
线程3大不安全案例
119 0
线程3大不安全案例 1.
|
安全
【多线程:转账例子】探究两个对象对应两个线程如何加锁
【多线程:转账例子】探究两个对象对应两个线程如何加锁
288 0
Java线程同步的一些例子
Java线程同步的一些例子
112 0
Java线程同步的一些例子
|
开发框架 .NET
IsBackground对线程的重要作用
原文:IsBackground对线程的重要作用 要点: 1、当在主线程中创建了一个线程,那么该线程的IsBackground默认是设置为FALSE的。 2、当主线程退出的时候,IsBackground=FALSE的线程还会继续执行下去,直到线程执行结束。
930 0