生产者代码示例

 

 

一.必须按配置

Properties props = new Properties();
props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, "127.0.0.19092");//kafka broker地址
props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.StringSerializer");//key序列化
props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.StringSerializer");//value序列化

二.创建生产者

Producer<String, String> producer = new KafkaProducer<>(props);

三.创建ProducerRecord
var producerRecord = new ProducerRecord<>("jc-kafka-1-topic-2", "testkey", "test-value");

四.异步发送消息
Future<RecordMetadata> send = producer.send(producerRecord);
五.同步发送消息
var recordMetadata = producer.send(producerRecord).get();

六.打印发送结果
System.out.println("partition " + recordMetadata.partition() + " offset " + recordMetadata.offset());
以上为最基础的发送消息实例,下面针对高级用法做些展示

一.创建ProducerRecord时指定timestamp,Partition,Header
ProducerRecord(String topic, Integer partition, Long timestamp, K key, V value, Iterable<Header> headers)

二.自定义分区方式
1.创建分区器,比如采用随机的方式
public class TestPartitioner implements Partitioner {

    private static final Random random = new Random();

    @Override
    public int partition(String topic, Object key, byte[] keyBytes, Object value, byte[] valueBytes, Cluster cluster) {
        var count = cluster.partitionCountForTopic(topic);
        return random.nextInt(count);
    }

    @Override
    public void close() {
    }

    @Override
    public void configure(Map<String, ?> configs) {
    }
}
2.使用分区器,需要修改生产者配置,增加以下
props.put(ProducerConfig.PARTITIONER_CLASS_CONFIG, TestPartitioner.class.getName());

三.自定义拦截器,方式和自定义分区器类似
1.创建拦截器,例如给value都加上前缀
public class TestInterceptor implements ProducerInterceptor<String, String> {
    @Override
    public ProducerRecord<String, String> onSend(ProducerRecord<String, String> record) {
        return new ProducerRecord<>(record.topic(), "pre" + record.value());
    }

    @Override
    public void onAcknowledgement(RecordMetadata metadata, Exception exception) {
    }

    @Override
    public void close() {
    }

    @Override
    public void configure(Map<java.lang.String, ?> configs) {
    }
}

2.使用拦截器,需要修改生产者配置,增加以下
props.put(ProducerConfig.INTERCEPTOR_CLASSES_CONFIG, TestInterceptor.class.getName());
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值