
com.github.sakserv.kafka.producer.KafkaReadfileProducer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kafka-readfile-producer Show documentation
Show all versions of kafka-readfile-producer Show documentation
Kafka Producer that reads input from a file
The newest version!
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.github.sakserv.kafka.producer;
import kafka.javaapi.producer.Producer;
import kafka.producer.KeyedMessage;
import kafka.producer.ProducerConfig;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.Properties;
public class KafkaReadfileProducer {
// Logger
private static final Logger LOG = LoggerFactory.getLogger(KafkaReadfileProducer.class);
private String kafkaHostname;
private Integer kafkaPort;
private String topic;
private String inputFileName;
private KafkaReadfileProducer(Builder builder) {
this.kafkaHostname = builder.kafkaHostname;
this.kafkaPort = builder.kafkaPort;
this.topic = builder.topic;
this.inputFileName = builder.inputFileName;
}
public String getKafkaHostname() {
return kafkaHostname;
}
public Integer getKafkaPort() {
return kafkaPort;
}
public String getTopic() {
return topic;
}
public String getInputFileName() {
return inputFileName;
}
public static class Builder {
private String kafkaHostname;
private Integer kafkaPort;
private String topic;
private String inputFileName;
public Builder setKafkaHostname(String kafkaHostname) {
this.kafkaHostname = kafkaHostname;
return this;
}
public Builder setKafkaPort(Integer kafkaPort) {
this.kafkaPort = kafkaPort;
return this;
}
public Builder setTopic(String topic) {
this.topic = topic;
return this;
}
public Builder setInputFileName(String inputFileName) {
this.inputFileName = inputFileName;
return this;
}
public KafkaReadfileProducer build() {
KafkaReadfileProducer kafkaReadfileProducer = new KafkaReadfileProducer(this);
return kafkaReadfileProducer;
}
}
public void produceMessages() {
Properties props = new Properties();
props.put("metadata.broker.list", getKafkaHostname() + ":" + getKafkaPort());
props.put("serializer.class", "kafka.serializer.StringEncoder");
ProducerConfig config = new ProducerConfig(props);
Producer producer = new Producer(config);
try(BufferedReader br = new BufferedReader(new FileReader(getInputFileName()))) {
String line = br.readLine();
while (line != null) {
KeyedMessage data = new KeyedMessage(getTopic(), null, line);
producer.send(data);
System.out.println(line);
Thread.sleep(100l);
line = br.readLine();
}
} catch (IOException e) {
e.printStackTrace();
} catch (InterruptedException e) {}
finally {
producer.close();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy