Kafka的生产者是向Kafka集群发送消息的部分,有很强的自主性,可以自主定义何时发送消息,发送怎样的消息。
但是发送消息无法发送集合列表,只能以key,value的形式发送消息,在设置消息发送的模式时可以参考value值为json格式的内容,可能存储更大量的参数值。
1、配置生产者参数
2、创建生产者实例
3、生成消息(主题,key,value)
4、发送消息
5、关闭生产者实例
import com.lmz.util.KafkaPara;
import org.apache.kafka.clients.producer.KafkaProducer;
import org.apache.kafka.clients.producer.ProducerRecord;
import java.util.Properties;
/**
* Kafka生产者客户端
* @author zeyue
*/
public class KafkaProducerTest {
/**
* 订阅主题名称
*/
public static final String topic = "test";
/**
* 生产者参数配置方法
* @return 返回配置好生产者参数的Properties类
*/
public static Properties initConfig() {
Properties props = new Properties();
props.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");
props.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");
props.put("bootstrap.servers", KafkaPara.brokerList);
props.put("client.id", "consumer.client.id.demo");
return props;
}
public static void main(String[] args) {
Properties properties = initConfig();
//创建Kafka生产者类
KafkaProducer<String , String> producer = new KafkaProducer<>(properties);
for (int i = 0 ; i < 20000 ; i++) {
ProducerRecord<String ,String > producerRecord = new ProducerRecord<>(topic,"test","Hello Kafka" + i);
producer.send(producerRecord);
}
producer.close();
}
}