Kafka源码分析--生产者

ps.本文所有源码都基于kafka-0.10.0.1

Kafka提供了Java版本的生产者实现--KafkaProducer,使用KafkaProducer的API可以轻松实现同步/异步发送消息、批量发送、超时重发等复杂的功能,KafkaProducer是线程安全的,多个线程之间可以共享实用同一个KafkaProducer对象。

下面先看一个使用上的小例子:

public static void main(String[] args) {
    boolean isAsync = args.length == 0 || !args[0].trim().equalsIgnoreCase("sync");
    Properties properties = new Properties();
    properties.put("bootstrap.servers", "localhost:9092");
    properties.put("client.id", "DemoProducer");
    properties.put("key.serializer", "org.apache.kafka.common.serialization.IntegerSerializer");
    properties.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");
    KafkaProducer producer = new KafkaProducer<>(properties);
    String topic = "test";

    int messageNo = 1;
    while(true) {
        String messageStr = "Message_" + messageNo;
        long startTime = System.currentTimeMillis();
        if(isAsync) {
            //ProducerRecord可以当成一个消息,包含key,value,和topic
            //异步要有回调函数
            producer.send(new ProducerRecord(topic, messageNo, messageStr), new DemoCallBack(startTime, messageNo, messageStr));
        } else { //同步发送
            try {
                //KafkaProducer.send()返回的类型是Future<RecordMetadata>
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值