package org.springService;
import java.util.Properties;
import org.apache.kafka.clients.producer.Callback;
import org.apache.kafka.clients.producer.KafkaProducer;
import org.apache.kafka.clients.producer.Producer;
import org.apache.kafka.clients.producer.ProducerRecord;
import org.apache.kafka.clients.producer.RecordMetadata;
/**
* 生产者
* @author zz
* @date 2018年9月13日
*/
public class ProducerDemo {
public final static String TOPIC="JAVA_TOPIC";
public static void main(String[] args){
Properties properties = new Properties();
properties.put("bootstrap.servers", "localhost:9092,localhost1:9092");
properties.put("acks", "all");
properties.put("retries", 0);
properties.put("batch.size", 16384);
properties.put("linger.ms", 1);
properties.put("buffer.memory", 33554432);
properties.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");
properties.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");
Producer producer = null;
try {
producer = new KafkaProducer(properties);
Thread.sleep(1000);
for (int i = 0; i < 100; i++) {
String msg = "Message 发送卡夫卡消息-------" + i;
producer.send(new ProducerRecord(TOPIC,i+"", msg), new Callback(){
@Override
public void onCompletion(RecordMetadata metadata, Exception exception) {
}});
System.out.println("Sent:" + msg);
}
} catch (Exception e) {
e.printStackTrace();
} finally {
producer.close();
}
}
}
package org.springService;
import java.util.Arrays;
import java.util.Properties;
import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.KafkaConsumer;
/**
* 消费者
* @author
* @date 2018年9月13日
*/
public class ConsumerDemo {
public static void main(String[] args){
Properties properties = new Properties();
properties.put("bootstrap.servers", "localhost:9092,localhost1:9092");
properties.put("group.id", "group-1");
properties.put("enable.auto.commit", "true");
properties.put("auto.commit.interval.ms", "1000");
properties.put("auto.offset.reset", "earliest");
properties.put("session.timeout.ms", "30000");
properties.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
properties.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
@SuppressWarnings("resource")
KafkaConsumer kafkaConsumer = new KafkaConsumer<>(properties);
//kafkaConsumer.subscribe(Arrays.asList(ProducerDemo.TOPIC1,ProducerDemo.TOPIC2));
kafkaConsumer.subscribe(Arrays.asList(ProducerDemo.TOPIC));
while (true) {
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
ConsumerRecords records = kafkaConsumer.poll(100);
for (ConsumerRecord record : records) {
System.out.printf("接受卡夫卡消息内容为——————————————》》offset = %d, value = %s", record.offset(), record.value());
System.out.println();
}
}
}
}