package com.message.server;
import org.apache.kafka.clients.consumer.*;
import java.util.Collections;
import java.util.Properties;
public class ServerKafka {
public static void main(String[] args) throws Exception {
String jaasTemplate = "org.apache.kafka.common.security.scram.ScramLoginModule required username=\"%s\" password=\"%s\";";
String jaasCfg = String.format(jaasTemplate, "bj520", "e865c246f6a511e883ef9cb6d56662c");
try {
Properties props = new Properties();
props.put("bootstrap.servers",
"192.168.0.1:9092;192.168.0.2:9093");
props.put("group.id","hm");
props.put("enable.auto.commit", "true");
props.put("auto.offset.reset", "latest");
props.put("auto.commit.interval.ms", "1000");
props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
props.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
// acl Authorizer
props.put("security.protocol", "SASL_PLAINTEXT");
props.put("sasl.mechanism", "PLAIN");
props.put("sasl.jaas.config", jaasCfg);
//String setProperty = System.setProperty("java.security.auth.login.config", jaasCfg); // 配置文件路径
System.out.println("receive KafkaData");
KafkaConsumer<String, String> consumer = new KafkaConsumer<>(props);
consumer.subscribe(Collections.singletonList("user_name_520"));
while (true) {
ConsumerRecords<String, String> records = consumer.poll(100);
for (ConsumerRecord<String, String> record : records) {
System.out.printf("consumer:>>>>>offset = %d, key= %s , value = %s\n", record.offset(),
record.key(), record.value());
}
}
} catch (Exception ex) {
ex.printStackTrace();
System.out.println("when calling kafka output error." + ex.getMessage());
}
}
}
group.id : hm
topic : user_name_520
kafka账号 : bj520
kafka密码 : e865c246f6a511e883ef9cb6d56662c
kafka地址 : 192.168.0.1:9092;192.168.0.2:9093