Avro生产者发送无键模式的键
创始人
2024-11-13 08:00:33
0

使用Avro生产者发送无键模式的消息,可以按照以下步骤进行:

  1. 首先,需要定义Avro消息的Schema。Schema定义了消息的结构,包括字段的名称、类型和顺序。可以使用Avro的Schema定义语言(或者JSON格式)定义Schema。
String schemaString = "{\"type\":\"record\",\"name\":\"Message\",\"fields\":[{\"name\":\"value\",\"type\":\"string\"}]}";
Schema schema = new Schema.Parser().parse(schemaString);
  1. 创建Avro Producer的配置。
Properties props = new Properties();
props.put("bootstrap.servers", "localhost:9092");
props.put("key.serializer", "org.apache.kafka.common.serialization.ByteArraySerializer");
props.put("value.serializer", "io.confluent.kafka.serializers.KafkaAvroSerializer");
props.put("schema.registry.url", "http://localhost:8081");
  1. 创建Avro Producer实例。
KafkaProducer producer = new KafkaProducer<>(props);
  1. 创建无键模式的Avro消息。
GenericRecord message = new GenericData.Record(schema);
message.put("value", "Hello Kafka!");
  1. 将消息发送到Kafka集群。
ProducerRecord record = new ProducerRecord<>("topic-name", message);
producer.send(record);

完整的示例代码:

import org.apache.avro.Schema;
import org.apache.avro.generic.GenericData;
import org.apache.avro.generic.GenericRecord;
import org.apache.kafka.clients.producer.KafkaProducer;
import org.apache.kafka.clients.producer.ProducerRecord;

import java.util.Properties;

public class AvroProducerExample {

    public static void main(String[] args) {
        // Define Avro Schema
        String schemaString = "{\"type\":\"record\",\"name\":\"Message\",\"fields\":[{\"name\":\"value\",\"type\":\"string\"}]}";
        Schema schema = new Schema.Parser().parse(schemaString);

        // Create Kafka Producer configuration
        Properties props = new Properties();
        props.put("bootstrap.servers", "localhost:9092");
        props.put("key.serializer", "org.apache.kafka.common.serialization.ByteArraySerializer");
        props.put("value.serializer", "io.confluent.kafka.serializers.KafkaAvroSerializer");
        props.put("schema.registry.url", "http://localhost:8081");

        // Create Kafka Producer instance
        KafkaProducer producer = new KafkaProducer<>(props);

        // Create Avro message
        GenericRecord message = new GenericData.Record(schema);
        message.put("value", "Hello Kafka!");

        // Send message to Kafka cluster
        ProducerRecord record = new ProducerRecord<>("topic-name", message);
        producer.send(record);

        // Close the producer
        producer.close();
    }
}

以上代码使用了Confluent提供的KafkaAvroSerializer,该序列化器可以将Avro消息转换为Kafka的字节数组格式。在使用KafkaAvroSerializer之前,需要确保已经启动了Schema Registry,并且配置了正确的URL。

相关内容

热门资讯

玩家攻略(靠谱WPK)外挂透明... 靠谱WPK新手教程相关信息汇总(需添加指定薇757446909获取下载链接);玩家攻略(靠谱WPK)...
教学盘点!广东雀神麻将让系统发... 教学盘点!广东雀神麻将让系统发好牌(辅助挂)太坑了竟然是真的有挂(有挂规律)-哔哩哔哩;玩家必备必赢...
专业讨论!川麻圈辅助器手机版,... 专业讨论!川麻圈辅助器手机版,wepoker开挂作弊详细,详细有挂(有挂技巧)-哔哩哔哩1、点击下载...
透视黑科技!边锋老友棋牌是有挂... 大家肯定在之前边锋老友棋牌是有挂或者边锋老友棋牌是有挂中玩过透视黑科技!边锋老友棋牌是有挂(WEpo...
玩家必看科普!鄱阳翻精系统发牌... WePoker透视辅助工具核心要点解析‌,玩家必看科普!鄱阳翻精系统发牌机制,uupoker有挂,详...
透视脚本!广东雀神辅助器最新兑... 1、透视脚本!广东雀神辅助器最新兑换码(透视)太坑了其实真的有挂(有挂教学)-哔哩哔哩;详细教程。2...
科技通报(来玩德州挂)外挂透明... 1、科技通报(来玩德州挂)外挂透明挂辅助app(外挂)德州ai机器人(2024已更新)(哔哩哔哩)。...
总算了解!边锋游戏辅助器,we... 这是一款非常优秀的边锋游戏辅助器 ia辅助检测软件,能够让你了解到边锋游戏辅助器中牌率当中全部隐藏参...
我来分享!边锋老友棋牌能装挂(... 我来分享!边锋老友棋牌能装挂(wepOke),太坑了其实真的有挂(有挂技巧)-哔哩哔哩;(需添加指定...
玩家必看科普(鱼扑克发牌规律)... 玩家必看科普(鱼扑克发牌规律)外挂透明挂辅助脚本(外挂)德州ai机器人(2020已更新)(哔哩哔哩)...