首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

kafka0.8生产者实例

本文简单介绍下kafka0.8的client的producer的实例。

maven

代码语言:javascript
复制
        <dependency>
            <groupId>org.apache.kafka</groupId>
            <artifactId>kafka_2.10</artifactId>
            <version>0.8.2.2</version>
        </dependency>

初始化

代码语言:javascript
复制
        Properties props = new Properties();
        props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG,brokerAddr);
        props.put(ProducerConfig.CLIENT_ID_CONFIG, "DemoProducer");
        props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.StringSerializer");
        props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.StringSerializer");
        KafkaProducer<String, String> producer = new KafkaProducer<>(props)

准备消息

代码语言:javascript
复制
                String dataKey = UUID.randomUUID().toString();
                String dataValue = UUID.randomUUID().toString();

                ProducerRecord<String, String> producerRecord = new ProducerRecord<>(
                        topic,
                        dataKey,
                        dataValue
                );

发送

同步发送

代码语言:javascript
复制
producer.send(producerRecord).get();

异步发送(默认)

代码语言:javascript
复制
producer.send(producerRecord);

使用callback

代码语言:javascript
复制
producer.send(producerRecord, new Callback() {
                    @Override
                    public void onCompletion(RecordMetadata metadata, Exception exception) {
                        if(exception != null){
                            LOGGER.error("send msg to {},error:{}",metadata.topic(),exception);
                        }
                    }
                });

doc

  • kafka08-documentation
  • Kafka Clients (At-Most-Once, At-Least-Once, Exactly-Once, and Avro Client)
举报
领券